我是靠谱客的博主 健康犀牛,最近开发中收集的这篇文章主要介绍基于hostpath的k8s pod日志持久化思考: step1:将日志挂载到nfsstep2:优化,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

思考:

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日志持久化

最后

以上就是健康犀牛为你收集整理的基于hostpath的k8s pod日志持久化思考: step1:将日志挂载到nfsstep2:优化的全部内容,希望文章能够帮你解决基于hostpath的k8s pod日志持久化思考: step1:将日志挂载到nfsstep2:优化所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(31)

评论列表共有 0 条评论

立即
投稿
返回
顶部