前言
为了密评而定时将nginx的日志按照月处理,然后定时同步到其他服务器上…
脚本
#!/bin/bash
# 备份nginx日志并保留6个月的日志
# 设置备份目录
backup_dir="/home/docker/nginx-outer-gateway/logs/backLog/"
# 日志目录
log_dir="/home/docker/nginx-outer-gateway/logs/"
# 备份access.log
cp $log_dir/access.log $backup_dir/access_$(date +\%Y-\%m-\%d).log
# 备份error.log
cp $log_dir/error.log $backup_dir/error_$(date +\%Y-\%m-\%d).log
# 清空nginx日志文件
echo "" > $log_dir/access.log
echo "" > $log_dir/error.log
# 定时删除服务器日志
find $backup_dir -name 'access_*' -mtime +90 -type f -delete
find $backup_dir -name 'error_*' -mtime +90 -type f -delete
# 同步备份的日志到目标服务器
rsync -avz -e ssh $backup_dir/*_$(date +\%Y-\%m-\%d).log root@服务器IP:/home/backup/nginx
定时任务
新增定时任务
crontab -e
配置策略
0 0 1 * * /home/docker/nginx-outer-gateway/logs/backRun.sh
查看定时任务
crontab -l
配置免密登陆
比如我需要将 192.168.1.1 的日志上传到 192.168.1.2 服务器上面去
- 在
192.168.1.1
上生成SSH密钥对:
ssh-keygen -t rsa
按照提示一路回车,生成密钥对(公钥和私钥)。
- 将公钥上传到目标服务器
ssh-copy-id user@192.168.1.2
静静等待即可,一会输入
192.168.1.2
服务器的密码即可