具備可以使本地和遠程兩臺主機之間的數據快速複製同步鏡像,遠程備份的功能,這個功能相似ssh帶的scp命令,但又優於scp命令的功能,scp每次都是全量拷貝,而rsync能夠增量拷貝。固然,Rsync還能夠在本地主機的不一樣分區或目錄之間全量及增量的複製數據,這又相似cp命令,但一樣也優於cp命令,cp每次都是全量拷貝,而rsync能夠增量拷貝。web
rsync的流氓屬性:我複製給你你所沒有的文件,同時刪除你有我沒有的文件(保存兩臺服務器數據的徹底同步)vim
#兩臺服務器都必須裝兩個軟件包 [root@yangwenbo /]# yum -y install rsync openssh-clients [root@yangwenbo /]# rpm -qa rsync openssh-clients openssh-clients-7.4p1-16.el7.x86_64 rsync-3.1.2-4.el7.x86_64
rsync 命令經常使用參數選項說明:服務器
v,--verbose 詳細模式輸出,傳輸時的進度等信息
z,--compress 傳輸時進行壓縮以提升傳輸效率,--compress-level=NUM可按級別壓縮。
a,--archive 歸檔模式,表示以遞歸方式傳輸文件,並保持全部文件屬性,等於-rtopgD1(字母1)網絡
/backup
推到本地的/yunwei
目錄相下/backup
裏有如下內容/yunwei
裏有如下內容/yunwei
目錄本地
共享目錄/backup
目錄下備份Web服務器/yangwenbo
目錄下本地
掛載備份備份Wbo服務器
檢查[root@root ~]# vim /etc/rsyncd.conf [root@root ~]# cat /etc/rsyncd.conf uid = rsync gid = rsync use chroot = no max connections = 200 timeout = 300 pid file = /var/run/rsyncd.pid lock file = /var/log/rcyncd.lock [backup] path = /backup/ ignore errors read only = false list = false hosts allow = 192.168.200.0/24 hosts deny = 0.0.0.0/24 auth users = rsync_backup secrets file = /etc/rsync.password
由客戶端操做:ssh
問題1:socket
@ERROR: chroot failed
rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3] 測試
緣由:服務器端的目錄不存在或無權限,建立目錄並修正權限可解決問題。 ui
問題2: this
@ERROR: auth failed on module tee
rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3] spa
緣由:服務器端該模塊(tee)須要驗證用戶名密碼,但客戶端沒有提供正確的用戶名密碼,認證失敗。
問題3:
@ERROR: Unknown module ‘tee_nonexists'
rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]
緣由:服務器不存在指定模塊。提供正確的模塊名或在服務器端修改爲你要的模塊以解決問題。
問題4: 在client上遇到問題:
4.1
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
4.2
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 ,這裏登錄名不可缺乏
問題5:
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
問題6:
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 來查看可用空間和已用空間
問題7:網絡收集問題
7.1 權限問題
相似以下的提示:
rsync: opendir "/kexue" (in dtsChannel) failed: Permission denied (13)
注意查看同步的目錄權限是否爲755
7.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設爲管理員便可)
7.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
7.4磁盤空間滿
rsync: recv_generator: mkdir "/teacherclubBackup/rsync……" failed: No space left on device (28)
*** Skipping any contents from this failed directory ***
7.5Ctrl+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服務器
問題8.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]
說明:原數據目錄裏沒有數據存在