前言
为了项目安全需要做服务器nginx日志异地备份。
一、具体实现
1.编写shell脚本文件
代码如下(示例):
参考脚本
#!/bin/bash
cp /usr/local/nginx/logs/access.log /data/nginxlog/access_$(date +\%Y-\%m-\%d).log # 备份access.log
cp /usr/local/nginx/logs/error.log /data/nginxlog/error_$(date +\%Y-\%m-\%d).log # 备份error.log
echo "" > /usr/local/nginx/logs/access.log # 清空nginx日志文件
echo "" > /usr/local/nginx/logs/error.log # 清空nginx日志文件
# 同步备份的日志到目标服务器
rsync -avz -e ssh /data/nginxlog/*_$(date +\%Y-\%m-\%d).log root@192.168.50.12:/data/nginxlog/$(date +\%Y-\%m-\%d)
2.编辑服务器定时任务
代码如下(示例):
crontab -e #编辑
0 0 1 * * /usr/local/nginx/logs/backRun.sh #写入shell脚本位置保存
service crond restart #重启定时任务
3.配置免密登录
比如我需要将 192.168.50.11 的日志上传到 192.168.50.12 服务器上面去
在 192.168.50.11 上生成SSH密钥对:
ssh-keygen -t rsa
按照提示一路回车,生成密钥对(公钥和私钥)。
将公钥上传到目标服务器
ssh-copy-id root@192.168.50.12 #ssh-copy-id 登录的用户@目标ip
静静等待即可,一会输入 192.168.50.12 服务器的密码即可
总结
以上就可以实现日志的异地备份。