基于hostpath的k8s pod日志持久化

思考:

1.考虑到pod的多副本,但同时需要将日志集中收集起来,所以采用hostpath的方式将同一个服务的多pod的日志持久化到一起,日志穿插性的写在一个文件中。


2.由于pod重启会打散分配到不同节点上,所以基于nfs的网络文件系统通过共享目录的方式挂载到客户端节点(nfs-server:/nfs; nfs-client: /mnt/hostpath,将nfs-server的/mnt/hostpath挂载到nfs-client的/mnt/hostpath下,从而达到同服务多pod可以写到一个文件中 )。


step1:将日志挂载到nfs

修改yaml文件:

        volumeMounts:#跟image同级
        - mountPath: /opt/logs/application/xxx-server
          name: log
      volumes:#跟containers:同级
      - name: log
        nfs:
          server: 192.168.220.224
          path: /nfs
          

将pod的副本数调整到三个,依然在/nfs只有一个日志目录,同时打开日志,会发现有三个pod服务启动加载时要读取的配置参数,说明pod的日志是穿插写入到文件中的。

step2:优化

有时间需要将同一个服务的多副本pod的日志持久化到本地,方便更加pod的名称更加快速的查看完整的日志,则可以通过subpathexpr可以实现,详见官网文档介绍。

        #添加容器环境变量
        - name: POD_NAME
          valueFrom:
            fieldRef:
              apiVersion: v1
              fieldPath: metadata.name
        volumeMounts:#跟image同级
        - mountPath: /opt/logs/application/xxx-server
          name: log
          subPathExpr: $(POD_NAME)
      volumes:#跟container同级
      - name: log
        nfs:
          server: 192.168.220.224
          path: /nfs

参考来源:基于hostpath的k8s pod日志持久化_最美dee时光的博客-CSDN博客_k8s日志持久化

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

均衡教派.

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

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

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

打赏作者

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

抵扣说明:

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

余额充值