远程调试在K8S的POD中的Java应用程序

前言

现在越来越多的公司选择利用Kubernetes来部署和管理Java应用,那么当运行在k8s中的应用运行异常时,除了看日志,远程调试也是个非常实用的办法。

接下来,本文将通过实际操作带大家学习如何远程调试!

启动项目

首先我们得有一个 Java 应用程序,它提供了一些 REST 端点,并且希望使用 IDE 对其进行调试。

让我们在 Spring Boot 中创建一个简单的应用程序,它提供了一个简单的 REST 端点。


@RestController
public class WebController {
    @GetMapping("/")
    public ResponseEntity get(){
        return ResponseEntity.ok("All Works fine");
    }
}

现在,我们通过maven中使用Google的 JIB 插件来创建此应用程序的docker镜像。

<plugin>
    <groupId>com.google.cloud.tools</groupId>
    <artifactId>jib-maven-plugin</artifactId>
    <version>3.2.1</version>
    <configuration>
        <from>
            <image>openjdk:17</image>
        </from>
        <to>
            <image>ghcr.io/amrutprabhu/${project.name}:${project.version}</image>
        </to>
    </configuration>
    <executions>
        <execution>
            <phase>verify</phase>
            <goals>
                <goal>build</goal>
            </goals>
        </execution>
    </executions>
</plugin>

当然,还有其它插件也可以用于创建docker镜像。

现在当我们运行mvn clean verify, 这个docker镜像会被构建出来,并推送到github 仓库中。

部署docker镜像到Kubernetes

此时需要有一个Kubernetes 集群来部署我们的应用程序。如果没有现成的,那我们可以使用 https://k3s.io 在本地运行一个轻量级Kubernetes集群。

我们将使用此 K3s 集群来部署我们的应用程序。

为了部署我们的应用程序,我们将创建一个包含部署定义的简单 helm 清单,如下所示。

apiVersion: apps/v1
kind: Deployment
metadata:
  name: application-deployment
spec:
  selector:
    matchLabels:
      app: application
  template:
    metadata:
      labels:
        app: application
    spec:
      containers:
        - image: ghcr.io/amrutprabhu/remote-application:1.0.0-SNAPSHOT
          imagePullPolicy: Always
          ports:
            - name: http
              containerPort: 8080
              protocol: TCP
            - name: debug-port
              containerPort: 5005
              protocol: TCP
          env:
            - name: JAVA_TOOL_OPTIONS
              value: '-Xdebug -agentlib:jdwp=transport=dt_socket,address=0.0.0.0:5005,server=y,suspend=n'

对我们来说,最重要的是在部署中设置的环境变量JAVA_TOOL_OPTIONS

由于我们使用的是 OpenJDK 映像,JVM 将选取此value环境变量以允许将调试器附加到端口 5005 .

现在可以使用 helm install <location of the helm chart> 命令来部署应用程序。

部署应用程序后,需要将 5005 端口进行转发以附加我们的调试器。

kubectl port-forward <your pod name> 5005:5005

同样,我们转发端口 8080 以调用我们的 REST 接口。

使用 Intellij 附加远程调试器

要附加调试器,请转到IDEA 右上角的运行部分并添加远程 JVM 调试运行配置。

命令行参数与我们指定为部署文件中的环境变量的值相同。

现在可以运行配置,调试器将被附加到对应应用。

使用 VSCode 附加远程调试器

要使用 VScode 附加远程调试器,我们需要添加启动配置,如下所示

{
  "version": "0.2.0",
  "configurations": [
    {
      "type": "java",
      "name": "Remote debugging RemoteApplication", // name for you your configuration
      "request": "attach",
      "hostName": "localhost",
      "projectName": "remote-application", //  your java project
      "port": "5005" // port to attach to
    }
  ]
}

要添加此启动配置,请转到左侧栏上的“运行和调试”,然后单击顶部的齿轮图标以打开launch.json

完成此操作后,启动配置,调试器将被附加。添加断点并在终结点上发送请求,以便调试器暂停执行,如下所示。

小结

本文介绍了如何打包springboot docker镜像,如何部署到k8s集群中, 以及如何通过idea或者vscode 远程调试k8s集群中的java应用程序。后续会针对docker和k8s进行更深入的介绍。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
k8s运行Java程序需要以下步骤: 1. 首先,你需要在本地构建一个Docker镜像,将你的Java应用程序打包并将其部署到k8s集群。你可以使用Dockerfile来定义镜像的构建过程,并且在其指定Java运行时环境。 2. 接下来,你需要创建一个Kubernetes Deployment对象来定义你的应用程序的部署配置。在Deployment对象,你需要指定要使用的镜像、容器端口、副本数等信息。 3. 确保你的k8s集群有一个可用的Service对象来公开你的应用程序。Service对象可以通过将流量转发到你的应用程序的容器来实现对外部访问的代理。 4. 最后,使用kubectl命令或通过编写一个YAML文件来创建Deployment和Service对象,并将其应用到k8s集群。 以下是一个示例的YAML文件,用于在k8s创建一个Deployment和Service对象来运行Java程序: ``` apiVersion: apps/v1 kind: Deployment metadata: name: environment spec: selector: matchLabels: app: environment replicas: 3 template: metadata: labels: app: environment spec: containers: - name: environment image: 192.168.2.251/qing/en:v1 ports: - containerPort: 8098 --- apiVersion: v1 kind: Service metadata: name: environment spec: selector: app: environment ports: - protocol: TCP port: 8098 targetPort: 8098 type: LoadBalancer ``` 你可以使用kubectl命令将上述YAML文件部署到k8s集群: ``` kubectl apply -f k8s.yaml ``` 这将创建一个名为"environment"的Deployment对象和一个名为"environment"的Service对象,并将你的Java应用程序部署到k8s集群

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全粘架构师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值