rsync同步

實驗環境:

服務端:192.168.0.134

客戶端:192.168.0.120

一.服務端操作

1.安裝rsync服務

yum -y install rsync


2.修改rsync的配置文件

vim /etc/xinetd.d/rsync

disable = yes 改成 disable = no

3.rsync主要有以下三個配置文件rsyncd.conf(主配置文件)、rsyncd.secrets(密碼文件)、rsyncd.motd(rysnc服務器信息)

服務器配置文件(/etc/rsyncd.conf),該文件默認不存在,請創建它。

vim /etc/rsyncd.conf

pid file = /var/run/rsyncd.pid   //告訴進程寫到 /var/run/rsyncd.pid 文件中

port = 873   //指定運行端口,默認是873,您可以自己指定

address = 192.168.0.134   //指定服務器IP地址

uid = root   //設置rsync運行權限root

gid = root   //設置rsync運行權限root

use chroot = no   //chroot,在傳輸文件之前,服務器守護程序在將chroot 到文件系統中的目錄中,這樣做的好處是可能保護系統被安裝漏洞侵襲的可能。缺點是需要超級用戶權限。另外對符號鏈接文件,將會排除在外。也就是說,你在 rsync服務器上,如果有符號鏈接,你在備份服務器上運行客戶端的同步數據時,只會把符號鏈接名同步下來,並不會同步符號鏈接的內容;這個需要自己來嘗試

read only = no   //不只讀,也可以寫

max connections = 20   //客戶端最多連接數

lock file = /var/run/rsync.lock   //鎖文件的存放位置

log file = /var/log/rsync.log   /日志文件位置,啓動rsync後自動產生這個文件,無需提前創建。

#motd file = /etc/rsyncd/rsyncd.motd   //motd file 是定義服務器信息的,要自己寫 rsyncd.motd 文件內容。當用戶登錄時會看到這個信息

[web]   //模塊名字,自己命名

path = /data/   //Rsync服務端數據目錄路徑

comment = rsync files   //註釋可以自己定義

ignore errors   //忽略IO

read only = no

list = yes   //顯示Rsync服務端資源列表

hosts allow = 192.168.208.129   //允許進行數據同步的客戶端IP地址,可以設置多個,用英文狀態下逗號隔開

#hosts deny =     //禁止數據同步的客戶端IP地址,可以設置多個,用英文狀態下逗號隔開

auth users = test   //同步驗證時用的賬號,如果沒有這項就是匿名同步,client同步時不用用戶名也能同步

secrets file = /etc/rsyncd.secrets   //密碼存在哪個文件

4.如果在配置文件中指定了歡迎信息,在/etc下創建rsyncd.motd,設置歡迎信息:

[root@hyj etc]# vim /etc/rsyncd.motd 
Welcome the rsync services!


5.在服務器端建立密碼文件 密碼文件格式很簡單,rsyncd.secrets的內容格式爲:

用戶名:密碼

在服務器端即A機:

vim /etc/rsyncd.secrets   //這個密碼文件要和配置文件中的保持一致

test:nibudong   //test爲驗證用戶,nibudong爲密碼

chmod 600 /etc/rsyncd.secrets   //修改權限爲600

6.啓動rsync服務

-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 873 -j ACCEPT  //在防火牆上將837端口開放

/usr/bin/rsync --daemon   //啓動rsync服務

killall -9 rsync   

rm -rf /var/run/rsyncd.pid   //每次重啓rsync都要先刪除pid文件

二.客戶端操作

1.安裝rsync服務即可

yum -y install rsync

2.創建密碼文件

vim /etc/rsyncd.passwd

nibudong

chmod 600 /etc/rsyncd.passwd 

3.同步數據到客戶端

/usr/bin/rsync -avHu --bwlimit=5000 --password-file=/etc/rsyncd.passwd [email protected]::test /data

-a, --archive 歸檔模式,表示以遞歸方式傳輸文件,並保持所有文件屬性,等於-rlptgoD

-v, --verbose 詳細模式輸出

-H, --hard-links 保留硬鏈結

-u, --update 僅僅進行更新,也就是跳過所有已經存在於DST,並且文件時間晚於要備份的文件。(不覆蓋更新的文件)

--bwlimit=KBPS 限制I/O帶寬,KBytes per second




Rsync的命令格式可以爲以下六種:

  rsync [OPTION]... SRC DEST
  rsync [OPTION]... SRC [USER@]HOST:DEST
  rsync [OPTION]... [USER@]HOST:SRC DEST
  rsync [OPTION]... [USER@]HOST::SRC DEST
  rsync [OPTION]... SRC [USER@]HOST::DEST
  rsync [OPTION]... rsync://[USER@]HOST[:PORT]/SRC [DEST]

對應於以上六種命令格式,rsync有六種不同的工作模式:


  1)拷貝本地文件。當SRC和DES路徑信息都不包含有單個冒號":"分隔符時就啓動這種工作模式。如:rsync -a /data /backup
  2)使用一個遠程shell程序(如rsh、ssh)來實現將本地機器的內容拷貝到遠程機器。當DST路徑地址包含單個冒號":"分隔符時啓動該模式。如:rsync -avz *.c foo:src
  3)使用一個遠程shell程序(如rsh、ssh)來實現將遠程機器的內容拷貝到本地機器。當SRC地址路徑包含單個冒號":"分隔符時啓動該模式。如:rsync -avz foo:src/bar /data
  4)從遠程rsync服務器中拷貝文件到本地機。當SRC路徑信息包含"::"分隔符時啓動該模式。如:rsync -av [email protected]::www /databack
  5)從本地機器拷貝文件到遠程rsync服務器中。當DST路徑信息包含"::"分隔符時啓動該模式。如:rsync -av /databack [email protected]::www
  6)列遠程機的文件列表。這類似於rsync傳輸,不過只要在命令中省略掉本地機信息即可。如:rsync -v rsync://172.16.78.192/www

rsync參數的具體解釋如下:

-v, --verbose 詳細模式輸出
-q, --quiet 精簡輸出模式
-c, --checksum 打開校驗開關,強制對文件傳輸進行校驗
-a, --archive 歸檔模式,表示以遞歸方式傳輸文件,並保持所有文件屬性,等於-rlptgoD
-r, --recursive 對子目錄以遞歸模式處理
-R, --relative 使用相對路徑信息

-z, --compress 對備份的文件在傳輸時進行壓縮處理
-b, --backup 創建備份,也就是對於目的已經存在有同樣的文件名時,將老的文件重新命名爲~filename。可以使用--suffix選項來指定不同的備份文件前綴。
--backup-dir 將備份文件(如~filename)存放在在目錄下。
-suffix=SUFFIX 定義備份文件前綴
-u, --update 僅僅進行更新,也就是跳過所有已經存在於DST,並且文件時間晚於要備份的文件。(不覆蓋更新的文件)
-l, --links 保留軟鏈結
-L, --copy-links 想對待常規文件一樣處理軟鏈結
--copy-unsafe-links 僅僅拷貝指向SRC路徑目錄樹以外的鏈結
--safe-links 忽略指向SRC路徑目錄樹以外的鏈結
-H, --hard-links 保留硬鏈結
-p, --perms 保持文件權限
-o, --owner 保持文件屬主信息
-g, --group 保持文件屬組信息
-D, --devices 保持設備文件信息
-t, --times 保持文件時間信息
-S, --sparse 對稀疏文件進行特殊處理以節省DST的空間
-n, --dry-run現實哪些文件將被傳輸
-W, --whole-file 拷貝文件,不進行增量檢測
-x, --one-file-system 不要跨越文件系統邊界
-B, --block-size=SIZE 檢驗算法使用的塊尺寸,默認是700字節
-e, --rsh=COMMAND 指定使用rsh、ssh方式進行數據同步
--rsync-path=PATH 指定遠程服務器上的rsync命令所在路徑信息
-C, --cvs-exclude 使用和CVS一樣的方法自動忽略文件,用來排除那些不希望傳輸的文件
--existing 僅僅更新那些已經存在於DST的文件,而不備份那些新創建的文件
--delete 刪除那些DST中SRC沒有的文件
--delete-excluded 同樣刪除接收端那些被該選項指定排除的文件
--delete-after 傳輸結束以後再刪除
--ignore-errors 及時出現IO錯誤也進行刪除
--max-delete=NUM 最多刪除NUM個文件
--partial 保留那些因故沒有完全傳輸的文件,以是加快隨後的再次傳輸
--force 強制刪除目錄,即使不爲空
--numeric-ids 不將數字的用戶和組ID匹配爲用戶名和組名
--timeout=TIME IP超時時間,單位爲秒
-I, --ignore-times 不跳過那些有同樣的時間和長度的文件
--size-only 當決定是否要備份文件時,僅僅察看文件大小而不考慮文件時間
--modify-window=NUM 決定文件是否時間相同時使用的時間戳窗口,默認爲0
-T --temp-dir=DIR 在DIR中創建臨時文件
--compare-dest=DIR 同樣比較DIR中的文件來決定是否需要備份
-P 等同於 --partial
--progress 顯示備份過程
--exclude=PATTERN 指定排除不需要傳輸的文件模式
--include=PATTERN 指定不排除而需要傳輸的文件模式
--exclude-from=FILE 排除FILE中指定模式的文件
--include-from=FILE 不排除FILE指定模式匹配的文件
--version 打印版本信息
--address 綁定到特定的地址
--config=FILE 指定其他的配置文件,不使用默認的rsyncd.conf文件
--port=PORT 指定其他的rsync服務端口
--blocking-io 對遠程shell使用阻塞IO
-stats 給出某些文件的傳輸狀態
--progress 在傳輸時現實傳輸過程
--log-format=formAT 指定日誌文件格式
--password-file=FILE 從FILE中得到密碼
--bwlimit=KBPS 限制I/O帶寬,KBytes per second
-h, --help 顯示幫助信息


一般都使用azv選項(如果windows與linux同步不建議使用這個參數)


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章