服务器日志异地备份


前言

为了项目安全需要做服务器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 服务器的密码即可

总结

以上就可以实现日志的异地备份。

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值