需求阐明:
如果你现在运维一个K8S平台,此平台由于各种原因最初架构筹划根本没有ELK之类的日记工具,然而研发部又每天向你要日记,实时日记也就算了,关键是要几个月以前哪天哪个点的,而生产环境大于天,没有领导批准绝对不乱动。
问题分析:
鉴于以上原因,需要写一个脚本把应用日记导出进行长久备份。
1、Pod日记最大保存70M左右,时限大概是2个小时
2、根据应用个数,日记大小,每天产生量,保留时限盘算需要硬盘大小
3、具体逻辑是:
根据应用名称获取所有Pod具体名字,挨个导出Pod日记,保留在当天的日记目录内,
而且不停不断的循环导出。
应用场景:
生产环境未筹划日记长久保存机制的临时解决方案,谁成想竞临时三年之久并仍在继续。
- #!/bin/bash
- #AUTHOR : Created by YaoButing
- #PLATFORM : CentOS Linux release 7.8.2003(2003)
- #VERSION : 3.0
- #DATE : 2021-09-08
- #DESCRIPTION : This script is used to Auto download the k8s logs .
- ###############################################################################
- #变量设置初始值
- NUMBER=100
- #/data/k8s-logs日志备份目录,根据需要提前规划计算好磁盘大小
- cd /data/k8s-logs
- while (($NUMBER>0))
- do
- #检查当日的日志目录是否存在,不存在则创建
- if [ -e /data/k8s-logs/`date "+%Y-%m-%d"` ]
- then
- echo "...........................目录已存在..........................."
- else
- mkdir /data/k8s-logs/`date "+%Y-%m-%d"`
- fi
- cd /data/k8s-logs/`date "+%Y-%m-%d"`/
- #下面两个01是一个编号,一个完整应用日志导出模块,根据应用个数复制添加即可
- ####--- 01 ---################# 导出 ABC 日志 ##################
- # CSDN为命名空间,其替换自己的namespace,ABC为应用名称
- for pod in ` kubectl get pod -n CSDN | grep ABC | awk '{print $1}' `
- do
- #每个Pod日志输出15s后停止,这个需要实际测试自己的Pod日志完全输出需要的时间
- timeout 15 kubectl logs -f $pod -n CSDN > /data/k8s-logs/`date "+%Y-%m-%d"`/ABC-`date "+%Y-%m-%d-%H-%M-%S"`.log
- echo " $pod 日志已导出......"
- done
- #将导出的应用所有Pod日志压缩打包
- tar -zcPvf /data/k8s-logs/`date "+%Y-%m-%d"`/ABC-`date "+%Y-%m-%d-%H"`.tar.gz /data/k8s-logs/`date "+%Y-%m-%d"`/ABC-`date "+%Y-%m-%d-%H"`*.log
- #删除导出的.log文件,只保留压缩包,节省空间
- rm -rf /data/k8s-logs/`date "+%Y-%m-%d"`/*.log
- ####--- 01 ---################# 导出 ABC 日志 ##################
- # sleep具体时间同样需要计算,要查看一个‘Pod保存日志的最长时限’,然后减去‘导出所有Pod日志消耗时间’,就是下面的时间,如果应用太多则可能不需要sleep
- sleep 3600
- done
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |