码迷,mamicode.com
首页 > 其他好文 > 详细

rsync实现数据同步

时间:2019-04-01 14:10:16      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:用户   脚本   客户   bin   生产   inetd   ash   gid   clu   

在生产环境中,我们通常需要一台服务器备份主服务器的数据和代码这些,而手动备份很麻烦且效率不高。所以我们使用rsync+crontab实现自动同步数据。

 

主服务器:192.168.1.1

备服务器:192.168.1.2

 

搭建原理:备服务器上创建备份模板、备份用户,并以守护进程的方式运行rsync。然后主服务器以此在定时任务执行同步脚本

 

1.在备服务器上安装软件包

yum -y install xinetd rsync

# 添加测试目录
mkdir /www

2.在主服务器上安装软件包

yum -y install rsync

# 添加测试目录
mkdir /www

3.备服务器修改配置

vim /etc/rsyncd.conf
uid=root
gid=root
address=192.168.1.2            #本机ip
port=873
hosts allow=192.168.1.0/24  #允许同步的客户端的地址
use chroot=yes                     #锁定家目录
max connections=5
pid file=/var/run/rsyncd.pid
lock file=/var/run/rsync.lock
log file=/var/log/rsyncd.log
 
[wwwroot]       # 共享模块的名称                      
    path=/www/
    comment=used for web-data root
    read only=false
    list=yes            # 是否允许查看模块信息
    auth users=rsyncuser   #用来同步的用户,不是系统用户
    secrets file =/etc/rsync.passwd   # 存放用户的密码文件
# 除此之外,还有指定不同步的文件的exclude、指定不进行压缩处理的dont compress。

# 创建密码文件
vim /etc/rsync.passwd
rsyncuser:123qqq...A

chmod 600 /etc/rsync.passwd

# 重启服务
systemctl start xinetd
systemctl enable xinetd
rsync --daemon --config=/etc/rsyncd.conf # 以守护进程并加载指定配置文件的方式启动

4.主服务器启动计划任务,定时的将数据备份给备服务器

# 创建密码文件
vim /etc/rsync.passwd
123qqq...A

# 创建执行同步的脚本
vim /scripts/autobackup.sh
#!/bin/bash
rsync -avz  /www/ rsyncuser@192.168.1.2::wwwroot --password-file=/etc/rsync.passwd

chmod +x /scripts/autobackup.sh

# 将脚本添加到定时任务
crontab -u root -e
03 3 * * * . /scripts/autobackup.sh

 

提示:如果同步失败,查看防火墙873端口是否开启

rsync实现数据同步

标签:用户   脚本   客户   bin   生产   inetd   ash   gid   clu   

原文地址:https://www.cnblogs.com/chenpingan/p/10635950.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!