k8s pod 生成 java dump文件方法

在运行java程序的时候有时候会出现oom等问题,这个时候就需要一些日志文件来查询具体的oom的原因,才能更好的找到问题并解决问题。

但是在容器中,每当容器重启后容器里面的所有数据都会消失,这时我们就需要把一些需要用到的文件通过持久化的方式挂载出来,这样即使容器重启了,需要的文件会保留到本地的。

本文通过nfs共享存储的方式将容器生成的dump文件挂载出来,方便研发查找问题

1、使用如下yaml

[root@kubernetes-master tmp]# cat data-platform_deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: data-platform
  name: data-platform
  namespace: default
spec:
  replicas: 1
  selector:
    matchLabels:
      app: data-platform
  template:
    metadata:
      labels:
        app: data-platform
    spec:
      containers:
      - name: data-platform
        image: 192.168.122.150/hc-public/data-platform:202304191015
        livenessProbe:
          httpGet:
            path: /data-platform/actuator/health
            port: 8080
          initialDelaySeconds: 50   # 这个要比readinessProbe的配置大点
          periodSeconds: 65   # 这个时间需要根据服务器的性能来设置,dump文件需要多少时间生成,这里就配置多长时间即可
          timeoutSeconds: 5
          failureThreshold: 1
        readinessProbe:
          httpGet:
            path: /data-platform/actuator/health
            port: 8080
          initialDelaySeconds: 40
          periodSeconds: 5
          successThreshold: 1
          timeoutSeconds: 5
        resources:
          requests:
            memory: "1536Mi"  # 此处很重要,这里的内存大小一定要比jvm的大1.5倍才行,不然无法生成dump文件
          limits:
            memory: "1536Mi"  # 此处很重要,这里的内存大小一定要比jvm的大1.5倍才行,不然无法生成dump文件
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 8080
        volumeMounts:
        - name: dump-file
          mountPath: /dump
      volumes:
      - name: dump-file
        nfs:   # 使用nfs共享存储来存储生成的dump文件
          server: 192.168.122.218
          path: /data/dump/public_data

说明:requests和limits一定要比jvm的内存配置大1.5倍,不然无法生成dump文件

2、jdk版本要大于等于1.8_181这个版本

/home/juser/project/data-platform # java -version
openjdk version "1.8.0_212"
OpenJDK Runtime Environment (IcedTea 3.12.0) (Alpine 8.212.04-r0)
OpenJDK 64-Bit Server VM (build 25.212-b04, mixed mode)```

猜你喜欢

转载自blog.csdn.net/ljx1528/article/details/130245737