解决方案—K8S集群的日志按天并按照命名空间分类定时同步到日志服务器

1. 备份需求

单节点k8s集群节点IP为10.10.14.155,需要把集群日志定时备份到远程日志服务器10.10.14.132,并保留日志服务器近半年的日志。

2. 解决方案

2.1 基于Shell脚本和Rsync的Shell脚本

复制代码
#!/bin/bash
# k8s_log_sync.sh

# 定义变量
LOG_BASE_DIR="/mnt/k8s_logs_rsync/k8s_logs"
DATE=$(date +"%Y-%m-%d")
REMOTE_USER="root"
REMOTE_SERVER="10.10.14.132"
REMOTE_BASE_DIR="/data/k8s_test_log_bak"

# 获取所有命名空间
NAMESPACES=$(kubectl get namespaces -o jsonpath='{.items[*].metadata.name}')

for NS in $NAMESPACES; do
    # 创建本地命名空间目录
    NS_LOG_DIR="$LOG_BASE_DIR/$DATE/$NS"
    mkdir -p $NS_LOG_DIR

    # 获取该命名空间下的所有Pod
    PODS=$(kubectl get pods -n $NS -o jsonpath='{.items[*].metadata.name}' 2>/dev/null)

    if [ -n "$PODS" ]; then
        for POD in $PODS; do
            echo "$(date) - 正在获取命名空间 $NS 中Pod $POD 的日志..."
            # 获取过去24小时的日志
            kubectl logs -n $NS $POD --since=24h > "$NS_LOG_DIR/${POD}.log" 2>/dev/null ||
            echo "无法获取Pod $POD 的日志" > "$NS_LOG_DIR/${POD}.error"
        done
    fi
done

# 同步到远程服务器
echo "开始同步日志到远程服务器..."
rsync -avz --progress -e ssh $LOG_BASE_DIR/$DATE/ $REMOTE_USER@$REMOTE_SERVER:$REMOTE_BASE_DIR/$DATE/

# 清理3天前的本地临时日志
find $LOG_BASE_DIR -type d -mtime +3 -exec rm -rf {} \;
echo "$(date) - 日志同步完成"

2.2 配置SSH密钥认证

复制代码
ssh-keygen -t rsa -b 4096
ssh-copy-id $REMOTE_USER@$REMOTE_SERVER

2.3 配置定时任务

复制代码
# 编辑crontab
crontab -e

# 添加以下行
0 2 * * * /bin/bash /path/to/k8s_log_sync.sh >> /var/log/k8s_log_sync.log 2>&1
相关推荐
松涛和鸣1 天前
49、智能电源箱项目技术栈解析
服务器·c语言·开发语言·http·html·php
德育处主任1 天前
『NAS』在群晖部署一个文件加密工具-hat.sh
前端·算法·docker
凉、介1 天前
SylixOS 中的 Unix Socket
服务器·c语言·笔记·学习·嵌入式·sylixos
RisunJan1 天前
Linux命令-ipcs命令(报告进程间通信(IPC)设施状态的实用工具)
linux·运维·服务器
HABuo1 天前
【Linux进程(四)】进程切换&环境变量深入剖析
linux·运维·服务器·c语言·c++·ubuntu·centos
橘颂TA1 天前
【Linux】死锁四条件的底层逻辑:从锁冲突到 STL 组件的线程安全实践(Ⅵ)
linux·运维·服务器·c++·死锁
运维栈记1 天前
虚拟化网络的根基-网络命名空间
网络·docker·容器
清水白石0081 天前
解构异步编程的两种哲学:从 asyncio 到 Trio,理解 Nursery 的魔力
运维·服务器·数据库·python
Joren的学习记录1 天前
【Linux运维大神系列】Kubernetes详解3(kubeadm部署k8s1.23高可用集群)
linux·运维·kubernetes