linux rsync 實現同步

 實現目標:

 
 A 服務器上 /opt/web 目錄,與B服務器上 /opt/web目錄實現同步。即:B主動與A進行同步。
 
OS: Reaht AS4
 
A Server  192.168.1.2 /opt/web
B Server  192.168.1.3 /opt/web
 
一. A Server config
 
1.rsync 系統自帶, 需要使用 --deamon 方式進行啓動,服務端口是 TCP 873
 
2. vi /etc/xinetd.d/rsync  修改 disable =yes 爲 disable =no ,修改後的文件如下
 
# default: off
# description: The rsync server is a good addition to an ftp server, as it \
#       allows crc checksumming etc.
service rsync
{
        disable = no
        socket_type     = stream
        wait            = no
        user            = root
        server          = /usr/bin/rsync
        server_args     = --daemon
        log_on_failure  += USERID
}
 
3. service   xinetd   restart,重啓 xinted 服務
 
4. 編輯主要配置文件 /etc/rsyncd.conf
 
vi /etc/rsyncd.conf
 
uid = nobody
gid = nobody
use chroot = no
max connections = 4
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsyncd.lock
log file = /var/log/rsyncd.log
 
[web]
path = /opt/web
#ignore errors (此選項可能導致錯誤提示,可註釋掉)
read only = true
list = false
hosts allow = 192.168.1.3 # 允許的IP地址
hosts deny = 0.0.0.0/32    # 禁止的IP 地址
auth users = backup        # 認證用戶名,此例是 backup
secrets file = /etc/backup.pass #認證用戶的密碼文件
 
5 編輯服務器的密碼文件 /etc/backup.pass
vi /etc/backup.pass
backup:123456
 
6. chmod 400 /etc/backup.pass
 
二. B Server  config
 
1. 編輯rsync連接時的密碼文件 /etc/rsync_client.pass
vi /etc/rsync_client.pass
123456                    # 只需要配置連接時使用的密碼即可,必須與A服務器上定義的密碼相同.
 
2. chmod 600 /etc/rsync_client.pass
 
3. 使用 rsync 命令連接服務器,實現文件同步
 rsync -vzrtopg --progress --delete --password-file=/etc/rsync_client.pass [email protected]::web /opt/web
 
4. 使用 --execlude= 排除不需要同步的文件後綴名
rsync -vzrtopg --progress --delete --password-file=/etc/rsync_client.pass --exclude="*.tmp" [email protected]::web /opt/web
 
5. 使用 --execlude-from= 排除不需要同步的目錄
[root@ASB opt]# rsync -vzrtopg --progress --delete --password-file=/etc/rsync_client.pass --exclude-from=/opt/pcdir [email protected]::web /opt/web
 
常見問題:
1、“2012/07/02 01:15:22 [31598] name lookup failed for 192.168.1.3: Name or service not known
2012/07/02 01:15:22 [31598] connect from UNKNOWN (192.168.0.104)”
問題是在需要在服務端這臺機上上的/etc/hosts裏面添加客戶端機的ip和機器名,如果有配DNS的話,那就不會有這樣的問題了。
/etc/hosts下設置一下你的IP 要不然每次服務器都會解釋你的ip地址尋找一個域名,所以會拖慢時間。如果你不是固定IP,那就只能忍了。
2、2012/07/02 01:15:22 [31598] rsync: chdir /web failed
: Permission denied (13)
問題在於SELinux,
解決辦法:
1、將SELinux設爲disabled,
2、執行命令setsebool -P rsync_disable_trans on
 
 
 
/opt/pcdir 文件的內容如下
cat /opt/pcdir
temp/
 
參數說明
   -vzrtopg裏的
             v是verbose,
             z是壓縮,
             r是recursive,
             topg都是保持文件原有屬性如屬主、時間的參數
   ----progress
              是指顯示出詳細的進度情況
    --delete  
             是指如果服務器端刪除了這一文件,那麼客戶端也相應把文件刪除,保持真正的一致             
   --exclude="*.tmp"
                 不包含某些文件  
   --execlude-from= 排除不需要同步的目錄
   --password-file
                 指定CLIENT端密碼文件存放路徑
     /opt/web/  
                  指定CLIENT端存放鏡象目的路徑
 
選項說明
 
-v, --verbose 詳細模式輸出
-q, --quiet 精簡輸出模式
-c, --checksum 打開校驗開關,強制對文件傳輸進行校驗
-a, --archive 歸檔模式,表示以遞歸方式傳輸文件,並保持所有文件屬性,等於-rlptgoD
-r, --recursive 對子目錄以遞歸模式處理
-R, --relative 使用相對路徑信息
 
rsync foo/bar/foo.c remote:/tmp/
 
則在/tmp目錄下創建foo.c文件,而如果使用-R參數:
 
rsync -R foo/bar/foo.c remote:/tmp/
 
則會創建文件/tmp/foo/bar/foo.c,也就是會保持完全路徑信息。
 
-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的shell程序
--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指定模式匹配的文件
--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 顯示幫助信息
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章