您当前的位置:首页 > 网络技术

linux 拒绝花钱 宝塔环境下手撸Rsync+crontab 增量备份

最近服务器到期,准备迁移服务器,那么问题来了,数据太多,搬迁过程中旧服务器还在继续跑数据,怎么破??

眼前摆在我眼前的就两条路,

       1、最简单的办法,半夜迁移数据,这就表明我要倒时差了

       2、想办法搞他!让我晚上能好好睡上一波,毕竟还年轻,要注重保养

话不多说,就是要选择第2种,不要问为什么,头铁!

重点来了,Rsync+crontab才最配

服务器用的是centos的宝塔环境,查了一下,宝塔竟然要收费!!!

一个月4块8.。我像是有钱的人吗??

直接查资料,手动搞!

下面是流程

a、b两台服务器,a为旧服务器,b 为新服务器,rsync也可以对服务器的负载均衡也会起到关键作用,后面必然会用到,后续再来填坑吧

首先往a服务器上配置

●Rsync  一般linux都会带上

a服务器记得开放873端口

没有的话,SSH连上,执行以下代码

yum -y install rsync

●安装完后,用宝塔进入/etc/rsyncd.conf

[aa] path=/www/wwwroot/aa/
use chroot=no
max connections=10
read only=yes
write only=no
list=no
uid=root
gid=root
auth users=root
secrets file=/etc/rsync_server.pas
strict modes=yes
hosts allow=*
#hosts deny=1.1.1.1
ignore errors=yes
timeout=120 #秒

       参数说明:
               [aa] :模块名,自己定义,可以在下方添加其它模块。须与客户端执行命令中的模块名一致。
               path:要备份的服务端文件夹路径。
               hosts allow:允许的客户端连接IP。
               secrets file:服务端密码文件,内容格式为,用户名:密码。
               auth users:有权限的用户名,与密码文件的中用户名一致。

      要手动在/etc目录创建一下下密码文件  rsync_server.pas  加入用户名与密码,内容格式为:用户名:密码。  如 root:123456

      创建完切记设置文件权限为600,所有者要跟密码文件中的用户名一致

 

 接下去启动rsync服务

# 启动rsync /usr/bin/rsync --daemon --config=/etc/rsyncd.conf

顺便说一下停止Rsync

# 停止rsync
ps -ef | grep rsync
kill -9 进程号
rm -rf /var/rsync/rsync.pid

接下去 b服务器配置

同样,rsync要是没装,就安装a服务所说的安装上

装完后,在/etc下创建密码文件rsync_client.pas,注意内容只有密码,且与a服务器密码文件中的密码相同。如123456

更改密码文件权限为600。这个非常重要,否则会无法同步

在b服务器添加定时任务crontab

直接编辑/etc/crontab文件,添加以下定时代码,保存

00 02 * * * root rsync -aqzrtopg --delete rsync://root@192.168.1.1/aa /home/aa_backup --password-file=/etc/rsync_client.pas

      参数说明                 

              192.168.1.1 假设为a服务器ip
              aa为服务端/etc/rsyncd.conf 文件中的[aa]模块
              /home/aa_backup 是b服务器文件夹路径
              /etc/rsync_client.pas为当前服务器的密码文件

完事,安心睡觉,定时2点(夜间执行备份操作比较稳妥,不会影响到白天服务器正常运行)会把代码同步到b服务器上

你觉得文章内容怎么样

阿里云代金券 100 云产品通用

有效期30天 首购用户

立即领取
阿里云代金券 100 云产品通用

有效期30天 复购+升级

立即领取