zoukankan      html  css  js  c++  java
  • Linux上rsync配置

    一、服务器端配置
    1、rsyncd.conf文件说明
    uid = rsync     #用户,用来控制用户访问模块目录的读写权限
    gid = rsync     #组,用来控制组访问模块目录的读写权限
    use chroot = no     #安全相关
    max connections = 50     #最大连接数
    timeout = 180     #超时时间(单位为秒)
    motd file = /etc/rsyncd/rsyncd.motd     #定义登录服务器时的banner信息
    pid file = /var/run/rsyncd.pid     #进程对应的进程号文件
    lock file = /var/run/rsync.lock     #锁文件
    log file = /var/log/rsyncd.log     #错误日志目录
    ignore errors     #忽略错误
    read only = false     #可写
    list = false     #不能查看服务器上有哪些模块
    hosts allow = 172.16.1.0/24 10.10.80.0/24     #允许访问的网段
    hosts deny = 0.0.0.0/0     #拒绝其它访问
    auth users = rsync     #远程访问用户名
    secrets file = /etc/rsync.password     #远程用户访问认证密码文件
    [backup]     #目录模块名
    path = /backup/     #目录路径
    [test]
    path = /test/
    说明:
    ignore errors选项最好加上,否则再很多crontab的时候往往发生错误你也未可知,因为你不可能天天去看每#时每刻去看log,不加上这个出现错误的几率相对会很高,因为任何大点的项目和系统,磁盘IO都是一个瓶颈

    2、创建rsyncd.conf文件
    [root@backup ~]#vim /etc/rsyncd.conf

    uid = rsync
    gid = rsync
    use chroot = no
    max connections = 30
    timeout = 300
    #motd file = /etc/rsyncd.motd
    pid file = /var/run/rsyncd.pid
    lock file = /var/run/rsync.lock
    log file = /var/log/rsyncd.log
    ignore errors
    read only = false
    list = false
    hosts allow = 10.47.39.0/24
    hosts deny = 0.0.0.0/0
    auth users = rsync
    secrets file = /etc/rsync.password
    
    [backup]
    path = /backup/

    [root@backup ~]#vim /etc/rsyncd.motd
    Welcome login rsync serser!!!!!!
    [root@backup ~]# useradd rsync -s /sbin/nologin -M
    [root@backup ~]# vim /etc/rsync.password
    rsync:123456
    [root@backup ~]# chmod 600 /etc/rsync.password
    [root@backup ~]# ll /etc/rsync.password
    -rw------- 1 root root 13 3月 8 21:51 /etc/rsync.password
    [root@backup ~]# rsync --daemon #启动rsync服务
    [root@backup ~]# ps -ef|grep rsync|grep -v grep
    root 31288 1 0 11:09 ? 00:00:00 rsync --daemon
    [root@backup ~]# mkdir /backup
    [root@backup ~]# chown -R rsync.rsync /backup
    [root@backup ~]# ls -lid /backup
    140545 drwx------ 2 rsync rsync 4096 2月 17 2017 /backup

    二、客户端配置
    [root@backup ~]# vim /etc/rsync.password
    123456
    [root@backup ~]# chmod 600 /etc/rsync.password
    [root@backup ~]# ll /etc/rsync.password
    -rw------- 1 root root 13 3月 8 21:51 /etc/rsync.password
    [root@backup ~]# rsync -avz /root/install.log rsync@10.47.39.8::backup --password-file=/etc/rsync.password

    三、rsync常用错误
    问题一:
    @ERROR: chroot failed
    rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]
    原因:
    服务器端的目录不存在或无权限,创建目录并修正权限可解决问题。

    问题二:
    @ERROR: auth failed on module backup
    rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]
    原因:
    服务器端该模块(backup)需要验证用户名密码,但客户端没有提供正确的用户名密码,认证失败。
    提供正确的用户名密码解决此问题。

    问题三:
    @ERROR: Unknown module ‘backup'
    rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]
    原因:
    服务器不存在指定模块。提供正确的模块名或在服务器端修改成你要的模块以解决问题。

    问题四:
    rsync -auzv --progress --password-file=/etc/rsync.pas root@192.168.133.128::backup /home/
    rsync: could not open password file "/etc/rsync.pas": No such file or directory (2)
    Password:
    @ERROR: auth failed on module backup
    rsync error: error starting client-server protocol (code 5) at main.c(1506) [Receiver=3.0.7]
    遇到这个问题:client端没有设置/etc/rsync.pas这个文件,而在使用rsync命令的时候,加了这个参数--
    password-file=/etc/rsync.pas

    问题五:
    rsync -auzv --progress --password-file=/etc/rsync.pas root@192.168.133.128::backup /home/
    @ERROR: auth failed on module backup
    rsync error: error starting client-server protocol (code 5) at main.c(1506) [Receiver=3.0.7]
    遇到这个问题:client端已经设置/etc/rsync.pas这个文件,里面也设置了密码111111,和服务器一致,但是
    服务器段设置有错误,服务器端应该设置/etc/rsync.pas ,里面内容root:111111 ,这里登陆名不可缺少

    问题六:
    rsync -auzv --progress --password-file=/etc/rsync.pas root@192.168.133.128::backup /home/
    @ERROR: chdir failed
    rsync error: error starting client-server protocol (code 5) at main.c(1506) [Receiver=3.0.7]
    遇到这个问题,是因为服务器端的/home/backup 其中backup这个目录并没有设置,所以提示:chdir failed

    问题七:
    rsync: write failed on "/home/backup2010/wensong": No space left on device (28)
    rsync error: error in file IO (code 11) at receiver.c(302) [receiver=3.0.7]
    rsync: connection unexpectedly closed (2721 bytes received so far) [generator]
    rsync error: error in rsync protocol data stream (code 12) at io.c(601) [generator=3.0.7]
    磁盘空间不够,所以无法操作。
    可以通过df /home/backup2010 来查看可用空间和已用空间

    问题八:网络问题
    1、权限问题
    类似如下的提示:rsync: opendir "/kexue" (in dtsChannel) failed: Permission denied (13)注意查看同步的目录权限是否为755

    2、time out
    rsync: failed to connect to 203.100.192.66: Connection timed out (110)
    rsync error: error in socket IO (code 10) at clientserver.c(124) [receiver=3.0.5]
    检查服务器的端口netstat –tunlp,远程telnet测试。
    可能因为客户端或者服务端的防火墙开启 导致无法通信,可以设置规则放行 rsync(873端口) 或者直接关闭防火墙。
    还有一种在同步过程中可能会提示没有权限 (将同步目录加上SvcwRsync全部权限即可,更简单的方法就是将SvcwRsync设为管理员即可)

    3、服务未启动
    rsync: failed to connect to 10.10.10.170: Connection refused (111)
    rsync error: error in socket IO (code 10) at clientserver.c(124) [receiver=3.0.5]
    启动服务:rsync --daemon --config=/etc/rsyncd.conf

    4、磁盘空间满
    rsync: recv_generator: mkdir "/teacherclubBackup/rsync……" failed: No space left on device (28)
    *** Skipping any contents from this failed directory ***

    5、Ctrl+C或者大量文件
    rsync error: received SIGINT, SIGTERM, or SIGHUP (code 20) at rsync.c(544) [receiver=3.0.5]
    rsync error: received SIGINT, SIGTERM, or SIGHUP (code 20) at rsync.c(544) [generator=3.0.5]
    说明:导致此问题多半是服务端服务没有被正常启动,到服务器上去查查服务是否有启动,然后查看下 /var/run/rsync.pid 文件是否存在,最干脆的方法是杀死已经启动了服务,然后再次启动服务或者让脚本加入系统启动服务级别然后shutdown -r now服务器

    6、xnetid启动
    rsync: read error: Connection reset by peer (104)
    rsync error: error in rsync protocol data stream (code 12) at io.c(759) [receiver=3.0.5]
    查看rsync日志
    rsync: unable to open configuration file "/etc/rsyncd.conf": No such file or directory
    xnetid查找的配置文件位置默认是/etc下,根据具体情况创建软链接。例如:
    ln -s /etc/rsyncd/rsyncd.conf /etc/rsyncd.conf
    或者更改指定默认的配置文件路径,在/etc/xinetd.d/rsync配置文件中。
    Rsync configure:
    配置一:
    ignore errors
    说明:这个选项最好加上,否则再很多crontab的时候往往发生错误你也未可知,因为你不可能天天去看每时每刻去看log,不加上这个出现错误的几率相对会很高,因为任何大点的项目和系统,磁盘IO都是一个瓶颈

    Rsync error:
    错误一:
    @ERROR: auth failed on module xxxxx
    rsync: connection unexpectedly closed (90 bytes read so far)
    rsync error: error in rsync protocol data stream (code 12) at io.c(150)
    说明:这是因为密码设置错了,无法登入成功,检查一下rsync.pwd,看客服是否匹配。还有服务器端没启动rsync 服务也会出现这种情况。

    错误二:
    password file must not be other-accessible
    continuing without password file
    Password:
    说明:这是因为rsyncd.pwd rsyncd.sec的权限不对,应该设置为600。如:chmod 600 rsyncd.pwd

    错误三:
    @ERROR: chroot failed
    rsync: connection unexpectedly closed (75 bytes read so far)
    rsync error: error in rsync protocol data stream (code 12) at io.c(150)
    说明:这是因为你在 rsync.conf 中设置的 path 路径不存在,要新建目录才能开启同步

    错误四:
    rsync: failed to connect to 218.107.243.2: No route to host (113)
    rsync error: error in socket IO (code 10) at clientserver.c(104) [receiver=2.6.9]
    说明:防火墙问题导致,这个最好先彻底关闭防火墙,排错的基本法就是这样,无论是S还是C,还有ignore errors选项问题也会导致

    错误五:
    @ERROR: access denied to www from unknown (192.168.1.123)
    rsync: connection unexpectedly closed (0 bytes received so far) [receiver]
    rsync error: error in rsync protocol data stream (code 12) at io.c(359)
    说明:此问题很明显,是配置选项host allow的问题,初学者喜欢一个允许段做成一个配置,然后模块又是同一个,致使导致

    错误六:
    rsync error: received SIGINT, SIGTERM, or SIGHUP (code 20) at rsync.c(244) [generator=2.6.9]
    rsync error: received SIGUSR1 (code 19) at main.c(1182) [receiver=2.6.9]
    说明:导致此问题多半是服务端服务没有被正常启动,到服务器上去查查服务是否有启动,然后查看下 /var/run/rsync.pid 文件是否存在,最干脆的方法是杀死已经启动了服务,然后再次启动服务或者让脚本加入系统启动服务级别然后shutdown -r now服务器

    错误七:
    rsync: read error: Connection reset by peer (104)
    rsync error: error in rsync protocol data stream (code 12) at io.c(604) [sender=2.6.9]
    说明:原数据目录里没有数据存在

    问题八:
    @ERROR: Unknown module ‘backup'
    rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]
    原因:
    服务器不存在指定模块。访问的服务器地址不在hosts allow里或模块名不正确

  • 相关阅读:
    SQL基础-子查询&EXISTS&UNION
    SQL基础-汇总统计及GROUP BY
    SQL基础-创建新的输出字段
    SQL基础-过滤数据
    获取图片为二进制流,并且显示图片到网页
    计算两个日期相差的工作小时数,过滤了周末双休小时数
    计算两个日期相差的工作天数,过滤了周末双休天数
    WEB性能测试工具
    C#整合VS2010和NUnit
    如何打开Windows Server 2008 R2的域安全策略
  • 原文地址:https://www.cnblogs.com/xwupiaomiao/p/8193950.html
Copyright © 2011-2022 走看看