linux rsync 指定用戶名和密碼的方式同步(轉)


rsync 客戶端 172.17.0.29

rsync 服務端 --daemon  方式運行 172.17.0.31 備份端

以下首先說明服務端的安裝情況:

1  檢查是否安裝rsync

    rpm -qa rsync

    rsync-3.0.6-12.el6.x86_64  如果沒有安裝進行yum 安裝即可

    yum install -y rsync

   yum install -y xinetd
  /etc/init.d/xinetd status
  /etc/init.d/xinetd restart

2  useradd rsync -s /sbin/nologin -M

    mkdir /backup

    chown rsync.rsync /backup

3  編寫rsync daemon 配置文件/etc/rsyncd.conf

   

 ##rsyncd.conf start###工作中指定用戶(需要指定用戶)
    uid = rsync
    gid = rsync
    use chroot = no
    max connections = 200
    timeout = 300
    pid file = /var/run/rsyncd.pid
    lock file = /var/run/rsync.lock
    log file = /var/log/rsyncd.log

   【backup】指定模塊

    path = /backup

    read only = false
    list = false
    hosts allow = 172.17.0.29/32 允許的地址連接
    hosts deny = 0.0.0.0/32  拒絕的地址連接
    auth users = rsync_backup #虛擬用戶名
    secrets file = /etc/rsync.password #對應的密碼

 

    rsync_config_______________end
        [backup01]   #注意這里指定模塊的方式方法,因為在客戶端需要指定這個地方,否則導致同步  失敗的奇葩現象
        path = /backup01

4  創建上述配置中指定的虛擬賬號和密碼:

    echo "rsync_backup:123456">/etc/rsync.password

   chmod 600 /etc/rsync.password # 注意權限

   [root@mfsmaster backup01]# cat /etc/rsync.password
    rsync_backup:123456

5  啟動服務

   rsync --daemon

 

  [root@mfsmaster backup01]# cat /etc/rc.local  追加開機啟動
#!/bin/sh
#
# This script will be executed *after* all the other init scripts.
# You can put your own initialization stuff in here if you don't
# want to do the full Sys V style init stuff.

touch /var/lock/subsys/local
/usr/local/mfs/sbin/mfsmaster start
rsync --daemon

which rsync

也可以echo "/etc/bin/rsync --daemon" >> /etc/rc.local

 

  [root@mfsmaster ~]# ps -ef |grep rsync
   root       1432      1  0 16:57 ?        00:00:00 rsync --daemon

  [root@mfsmaster ~]# ss -tnlp | grep rsync 查看873 存在873端口
LISTEN     0      5                        :::873                     :::*      users:(("rsync",1432,5))
LISTEN     0      5                         *:873                      *:*      users:(("rsync",1432,3)

[root@localhost /]# rsync -avz disk.txt rsync_backup@172.17.0.16::backup/ --password-file=/etc/rsync.password
rsync: failed to connect to 172.17.0.16: No route to host (113)
rsync error: error in socket IO (code 10) at clientserver.c(124) [sender=3.0.6]
You have new mail in /var/spool/mail/root

出現錯誤的方法:

檢查服務器的端口netstat –tunlp,遠程telnet測試。
可能因為客戶端或者服務端的防火牆開啟 導致無法通信,可以設置規則放行 rsync(873端口) 或者直接關閉防火牆。

6  客戶端的安裝方法:

      echo "123456" > /etc/rsync.password # 這里只填寫密碼即可

      chmod 600 /etc/rsync.password # 注意權限 (這一步不配置出現password file must not be other-accessible
continuing without password file
Password:
@ERROR: auth failed on module backup
rsync error: error starting client-server protocol (code 5) at main.c(1503) [sender=3.0.6])

       rsync -avz moosefs-3.0.81-1.tar.gz rsync_backup@172.17.0.31::backup01 --password-file=/etc/rsync.password # 目錄同步並指定相應的密碼文件

rsync -avzp --delete /data rsync_backup@172.17.0.32::backup01 --password-file=/etc/rsync.password

      注意:這里/data 目錄的區別

               /data 同步目錄

               /data/ 同步目錄下的文件

               /data/* 同步目錄下的文件

 [root@mqsql29 /]# scp -r /data/ root@172.17.0.32:/backup2016/ 復制目錄

scp -r /data/* root@172.17.0.32:/backup2016/    復制目錄下的文件

 

如果不想用文件的話,可以export RSYNC_PASSWORD="xxxxxx"的方式

export RSYNC_PASSWORD="123456"

轉自:https://blog.51cto.com/study2008/1873338


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM