簡介:
官網:https://download.samba.org/pub/rsync/rsync.htmlhtml
Rsync是一款開源的,快速的,多功能的,可實現全量及增量的本地或者遠程數據同步備份的優秀工具node
Rsyc本機簡單操做
拷貝文件算法
[root@Linux-node5-example ~]# rsync -avz /etc/hosts /opt/
拷貝文件夾shell
[root@Linux-node5-example ~]# rsync -ravz /etc /opt/
查看文件vim
[root@Linux-node5-example ~]# rsync /etc/hosts -rw-r--r-- 558 2018/06/27 21:56:59 hosts
遠程拷貝安全
[root@Linux-node5-example ~]# rsync -avz /etc/hosts root@192.168.10.22:/mnt/
Rsync守護進程方式
服務端配置:服務器
編寫配置文件:ssh
[root@Linux-node6-example mnt]# vim /etc/rsyncd.conf #指定rsync服務運行的時候向磁盤寫入讀取的操做者 uid = rsync gid = rsync #安全相關 use chroot = yes #最大鏈接數 max connections = 10 #指定PID文件路徑 pid file = /var/run/rsyncd.pid #鎖文件 lock file = /var/run/rsync.lock #日誌文件 log file = /var/log/rsyncd.log # exclude = lost+found/ #開啓Rsync數據傳輸日誌功能 transfer logging = yes #超時時間 timeout = 900 # ignore nonreadable = yes #指定那些文件在傳輸的時候不進行壓縮處理 dont compress = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2 #模塊名稱 [backup] #模塊對應位置 path = /www #忽略錯誤文件 ignore errors #是否只讀 read only = false #是否能夠列表 list = false #容許rsync白名單 hosts allow = 192.168.10.0/24 #禁止訪問黑名單 hosts deny = 0.0.0.0/32 #不存在的用戶,只用於認證 auth users = rsync_backup,rsync_yan #設置進行鏈接的祕鑰 secrets file = /etc/rsync.password
建立啓動用戶以及文件夾:工具
[root@Linux-node6-example ~]# useradd -s /sbin/nologin -M rsync [root@Linux-node6-example ~]# mkdir /www [root@Linux-node6-example ~]# chown -R rsync. /www/
編輯認證文件及權限:ui
[root@Linux-node6-example ~]# cat /etc/rsync.password rsync_backup:yan123456
[root@Linux-node6-example ~]# chmod 600 /etc/rsync.password
啓動rsync
[root@Linux-node6-example ~]# ps -ef | grep rsync root 18630 1 0 23:14 ? 00:00:00 rsync --daemon root 18632 18240 0 23:14 pts/0 00:00:00 grep --color=auto rsync
客戶端配置
配置密碼:
[root@Linux-node5-example ~]# cat /etc/rsync.password yan123456 [root@Linux-node5-example ~]# chmod 600 /etc/rsync.password
推送數據:
#密碼驗證模式 [root@Linux-node5-example ~]# rsync -avz /root/tui1 rsync_backup@192.168.10.22::backup Password: #免祕鑰交互模式 [root@Linux-node5-example ~]# rsync -avz /root/tui2 rsync_backup@192.168.10.22::backup --password-file=/etc/rsync.password
拉去數據:
#密碼認證模式 [root@Linux-node5-example ~]# rsync -avz rsync_backup@192.168.10.22::backup /www/ Password: #免密碼模式 [root@Linux-node5-example ~]# rsync -avz rsync_backup@192.168.10.22::backup /www/ --password-file=/etc/rsync.password
Rsync參數說明
-v, --verbose 詳細模式輸出。 -q, --quiet 精簡輸出模式。 -c, --checksum 打開校驗開關,強制對文件傳輸進行校驗。 -a, --archive 歸檔模式,表示以遞歸方式傳輸文件,並保持全部文件屬性,等於-rlptgoD。 -r, --recursive 對子目錄以遞歸模式處理。 -R, --relative 使用相對路徑信息。 -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 顯示備份過程。 -z, --compress 對備份的文件在傳輸時進行壓縮處理。 --exclude=PATTERN 指定排除不須要傳輸的文件模式。 --include=PATTERN 指定不排除而須要傳輸的文件模式。 --exclude-from=FILE 排除FILE中指定模式的文件。 --include-from=FILE 不排除FILE指定模式匹配的文件。--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 顯示幫助信息