在运行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)```