设为首页 收藏本站
查看: 1019|回复: 0

[经验分享] CentOS 6.3 Rsync服务端与Debian 6.0.5 Rsync客户端实现数据同步+rsync+Inotify实现数据的实时同步更新

[复制链接]

尚未签到

发表于 2018-5-15 09:27:02 | 显示全部楼层 |阅读模式
  来源:iyunv.com 作者:qihang01
  -------------
  说明:
  1、Rsync服务端
  系统:CentOS 6.3
  IP地址:192.168.21.132
  数据存放目录:/data/iyunv
  2、Rsync客户端
  系统:Debian 6.0.5
  IP地址:192.168.21.144
  同步的目录:/data/iyunv
  实现目的:
  Rsync客户端每天凌晨3:00自动同步Rsync服务端/data/iyunv目录中的数据到自己的/data/iyunv目录
  一、Rsync服务端配置
  1、关闭SELINUX
  vi /etc/selinux/config #编辑防火墙配置文件
  #SELINUX=enforcing #注释掉
  #SELINUXTYPE=targeted #注释掉
  SELINUX=disabled #增加
  :wq! #保存,关闭
  shutdown -r now #重启系统
  2、开启防火墙tcp 873端口(Rsync默认端口)
  vi /etc/sysconfig/iptables #编辑防火墙配置文件
  -A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 873 -j  ACCEPT
  :wq! #保存
  /etc/init.d/iptables restart #最后重启防火墙使配置生效
  3、安装Rsync服务端软件
  yum install rsync xinetd #安装
  vi /etc/xinetd.d/rsync #编辑配置文件,设置开机启动rsync
  disable = no #修改为
  /etc/init.d/xinetd start #启动(CentOS中是以xinetd来管理Rsync服务的
  系统运维 温馨提醒:qihang01原创内容版权所有,转载请注明出处及原文链接
  4、创建rsyncd.conf配置文件
  vi /etc/rsyncd.conf #创建配置文件,添加以下代码
  log file = /var/log/rsyncd.log #日志文件位置,启动rsync后自动产生这个文件,无需提前创建
[iyunv] #自定义名称

  path = /data/iyunv #Rsync服务端数据目录路径
  comment = iyunv  #模块名称与[iyunv]自定义名称相同
  uid = root #设置rsync运行权限为root
  gid = root #设置rsync运行权限为root
  port=873 #默认端口
  read only =yes #设置Rsync服务端文件为只读
  auth users = iyunvbakuser #执行数据同步的用户名,可以设置多个,用英文状态下逗号隔开
  # 认证的用户名,如果没有这行则表明是匿名,此用户与系统无关---可以不用useradd添加到系统上;
  secrets file = /etc/rsync.pass #用户认证配置文件,里面保存用户名称和密码,后面会创建这个文件
  hosts allow = 192.168.21.144  #允许进行数据同步的客户端IP地址,可以设置多个,用英文状态下逗号隔开
  hosts deny = 192.168.21.254  #禁止数据同步的客户端IP地址,可以设置多个,用英文状态下逗号隔开
  list = yes #显示Rsync服务端资源列表
  :wq! #保存,退出
  5、创建用户认证文件
  vi /etc/rsync.pass #配置文件,添加以下内容
  iyunvbakuser:123456 #格式,用户名:密码,可以设置多个,每行一个用户名:密码
  :wq! #保存,退出
  6、设置文件权限
  chmod 600 /etc/rsyncd.conf #设置文件所有者读取、写入权限
  chmod 600 /etc/rsync.pass #设置文件所有者读取、写入权限
  7、启动rsync
  /etc/init.d/xinetd start #启动
  service xinetd stop #停止
  service xinetd restart #重新启动
  二、Rsync客户端安装
  1、开启防火墙tcp  873端口(Rsync客户端不需要开启873端口,这里开启是为了方便以后作为Rsync服务端)
  说明:Debian默认安装是没有开启任何防火墙的
  为了服务器的安全,建议大家安装启用防火墙设置,这里推荐使用iptables防火墙
  whereis iptables #查看系统是否安装防火墙
  iptables: /sbin/iptables /usr/share/iptables  /usr/share/man/man8/iptables.8.gz #表示已经安装iptables防火墙
  apt-get install iptables #如果默认没有安装,请运行此命令安装防火墙
  iptables -L #查看防火墙配置信息,显示如下:
  #####################################################
  Chain INPUT (policy ACCEPT)
  target prot opt source destination
  Chain FORWARD (policy ACCEPT)
  target prot opt source destination
  Chain OUTPUT (policy ACCEPT)
  target prot opt source destination
  #####################################################
  nano /etc/iptables.default.rules #设置防火墙规则,添加以下内容
###############################################################################
*filter
# Allows  all loopback (lo0) traffic and drop all traffic to 127/8 that doesn't use  lo0
-A INPUT -i lo -j  ACCEPT
# Accepts all established inbound  connections
-A INPUT -m state --state  ESTABLISHED,RELATED -j ACCEPT
# Allows  all outbound traffic
# You could modify  this to only allow certain traffic
-A  OUTPUT -j ACCEPT
# Allows HTTP and  MySQLconnections from anywhere (the normal ports for websites)
-A INPUT -p tcp --dport 80 -j ACCEPT
-A INPUT -p tcp --dport 3306 -j ACCEPT
-A INPUT -p tcp --dport 873 -j ACCEPT
# Allows SSH connections for script  kiddies
# THE -dport NUMBER IS THE SAME  ONE YOU SET UP IN THE SSHD_CONFIG FILE
-A  INPUT -p tcp -m state --state NEW --dport 22 -j ACCEPT
# Now you should read up on iptables rules and consider  whether ssh access
# for everyone is  really desired. Most likely you will only allow access from certain  IPs.
# Allow ping
-A INPUT -p icmp -m icmp --icmp-type 8 -j  ACCEPT
# log iptables denied calls  (access via 'dmesg' command)
-A INPUT -m  limit --limit 5/min -j LOG --log-prefix "iptables denied: " --log-level  7
# Reject all other inbound - default  deny unless explicitly allowed policy:
-A  INPUT -j REJECT
-A FORWARD -j  REJECT
COMMIT
###############################################################################
  ctrl+o #保存
  ctrl+x #退出
  备注:873是Rsync端口
  iptables-restore < /etc/iptables.default.rules #使防火墙规则生效
  nano /etc/network/if-pre-up.d/iptables #创建文件,添加以下内容,使防火墙开机启动
  #!/bin/bash
  /sbin/iptables-restore </etc/iptables.default.rules
  ctrl+o #保存
  ctrl+x #退出
  chmod +x /etc/network/if-pre-up.d/iptables #添加执行权限
  2、安装Rsync客户端软件
  whereis rsync #查看系统是否已安装rsync,出现下面的提示,说明已经安装
  rsync: /usr/bin/rsync /usr/share/man/man1/rsync.1.gz
  apt-get install rsync  #如果没有安装,请执行这行命令来安装rsync
  nano /etc/default/rsync #编辑配置文件
  RSYNC_ENABLE=true  #把false改为true,设置开机启动rsync
  ctrl+o #保存
  ctrl+x #退出
  /etc/init.d/rsync start #启动
  #客户端-若提示无法启动 也没问题--也可以跟server端同步;
  service rsync stop #停止
  service rsync restart #重新启动
  3、测试Rsync客户端是否与Rsync服务端通信成功
  apt-get install telnet #安装telnet工具
  telnet 192.168.21.132 873 #输入命令后回车,如下图所示,表示通信成功

  三、设置Rsync客户端与Rsync服务端同步数据(以下操作在Rsync客户端进行)
  1、测试数据同步,在终端命令行输入
  rsync -vzrtopg --port=873 --progress --delete  iyunvbakuser@192.168.21.132::iyunv /data/iyunv

  提示输入密码:123456
  注意:此处的密码为Rsync服务端/etc/rsync.pass文件配置的密码
  回车之后,图下图所示,表示数据同步成功

  系统运维 温馨提醒:qihang01原创内容版权所有,转载请注明出处及原文链接
  cd /data/iyunv #进入数据同步目录
  ls #显示文件信息

  可以看到数据已经存在了
  2、添加计划任务,每天自动执行数据同步脚本
  nano /etc/passwd.txt #配置文件,添加以下内容
  123456 #密码
  ctrl+o #保存
  ctrl+x #退出
  chmod 600 /etc/passwd.txt  #设置文件权限,只设置文件所有者具有读取、写入权限即可
  cd /home
  nano iyunvbak.sh #编辑,添加以下内容
  #!/bin/sh
  rsync -vzrtopg --port=873 --progress --delete  iyunvbakuser@192.168.21.132::iyunv /data/iyunv  --password-file=/etc/passwd.txt
  ctrl+o #保存
  ctrl+x #退出
  chmod +x /home/iyunvbak.sh  #添加脚本直接权限
  3、添加计划任务
  系统运维 温馨提醒:qihang01原创内容版权所有,转载请注明出处及原文链接
  修改/etc/crontab
  nano /etc/crontab #在下面添加
  0 3 * * * root /home/iyunvbak.sh #表示每天凌晨3点执行备份
  ctrl+o #保存
  ctrl+x #退出
  6、重新启动crond使设置生效
  service cron stop #停止
  service cron start #启动
  /etc/init.d/cron restart #重启
  chkconfig cron on #设为开机启动,先要安装chkconfig(apt-get install chkconfig)
  至此,CentOS 6.3 Rsync服务端与Debian 6.0.5  Rsync客户端实现数据同步完成


  若与之同步的是客户端centos-rsync客户端-操作步骤是
  1.centos客户端安装rsync xinetd 并启动rsync 后就可以执行同步了
  #rsync -vzrtopg --port=873 --progress --delete  iyunvbakuser@192.168.21.132::iyunv /data/iyunv
  输入密码
  -----------------
  注
  1. CentOS 6.3 Rsync客户端与Windows Server 2003 cwRsyncServer服务端--搭建步骤如下链接
  http://www.dedecms.com/knowledge/servers/linux-bsd/2012/0819/8524.html

  ------------
rsync+Inotify实现数据的实时同步更新--(此部分)
  参考:构建高可用Linux服务器    余洪春
  http://book.51cto.com/art/201111/300715.htm

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-460308-1-1.html 上篇帖子: Debian用vi修改IP地址 下篇帖子: debian5 升级 debian6
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表