伺服器之間常常要保持些檔案或目錄的一致,比如一些大的軟體下載網站,它們通常使用多臺伺服器來提供下載服務。當一臺伺服器上的檔案更新後,其它的伺服器 也需要更新,而且 在更新的時候應該是隻對新增或是修改過的檔案進行更新,否則會造成網路頻寬和時間的浪費。rsync就是能有效的保持檔案及目錄的一致的優秀軟體。
rsync,remote synchronize
顧名思意就知道它是一款實現遠端同步功能的軟體,它在同步檔案的同時,可以保持原來檔案的許可權、時間、軟硬連結等附加資訊,而且可以通過ssh方式來傳輸檔案,這樣其保密性也非常好,另外它還是免費的軟體。rysnc的官方網站:http://rsync.samba.org/,可以從上面得到最新的版本。當然,因為rsync是一款如此有用的軟體,所以很多Linux的發行版本都將它收錄在內了。你的Linux裡並沒有安裝rsync,你可以按以下的安法自行安裝:
一、安裝過程
1.下載rsync
目前(2003年9月)最新的rsync版本是2.5.6,從rysnc的官方網站上下載一個回來:
# wget http://ftp.samba.org/ftp/rsync/rsync-2.5.6.tar.gz
2.解壓
# tar -xzpvf rsync-2.5.6.tar.gz
3.編譯安裝
# cd rsync-2.5.6/
# ./configure --prefix=/usr/local/rsync
# make
# make install
以上過程沒有出現的話就安裝好了,現在就有rsync命令可以用了,rsync命令放在
/usr/local/rsync/bin。用rsync命令可以去執行有rsync服務的伺服器上抓取資料。
如果要把當前的機器變成一臺rsync伺服器的話,就需要繼續進行一些配置了。
二、配置rsync服務
配置一個簡單的rsync服務並不複雜,你需要修改或建立一些配置檔案。
1.rsyncd.conf
# vi /etc/rsyncd.motd
rsyncd.con是rsync服務的主要配置檔案,它控制rsync服務的各種屬性,下面給出一個
rsyncd.conf檔案的例子:
#先定義整體變數
secrets file = /etc/rsyncd.secrets
motd file = /etc/rsyncd.motd
read only = yes
list = yes
uid = nobody
gid = nobody
hosts allow = 192.168.100.90 #哪些電腦可以訪問rsync服務
hosts deny = 192.168.100.0/24 #哪些電腦不可以訪問rsync服務
max connections = 2
log file = /var/log/rsyncd.log
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
#再定義要rsync目錄
[terry]
comment = Terry 's directory from 192.168.100.21
path = /home/terry
auth users = terry,rsync
[test]
comment = test rsync
path = /home/test
在上面的配置檔案中,限定了192.168.100.0/24這個子網中,只有192.168.100.90的機器可以來訪問這臺rsync伺服器的 rsync服務。配置檔案的後面部分定義了兩個rsync的目錄,terry目錄是隻有知道terry、rsync兩個賬號的人才能使用的,而text目 錄是無需賬號就可以訪問的。rsync在定義目錄時還提供了一些其它選項,可以作更嚴格的控制。
2.rsyncd.secrets
# vi /etc/rsyncd.secrets
rsyncd.secrets是儲存rsync服務的使用者名稱和密碼的,它是一個明文的文字檔案,下面給出一個rsyncd.secrets檔案的例子:
terry:12345
rsync:abcde
因為rsyncd.secrets儲存了rsync服務的使用者名稱和密碼,所以非常重要,因此檔案的屬性必須
設為600,只有所有者可以讀寫:
# chmod 600 /etc/rsyncd.secrets
3.rsyncd.motd
# vi /etc/rsyncd.motd
rsyncd.motd記錄了rsync服務的歡迎資訊,你可以在其中輸入任何文字資訊,如:
Welcome to use the rsync services!
4.services
# vi /etc/services
services並不是rsync的配置檔案,這一步也可以不做。而修改了services檔案的好處就在於
系統知道873埠對就的服務名為rsync。修改services的方法就是確保services中有如下兩行,
沒有的話就自行加入:
rsync 873/tcp # rsync
rsync 873/udp # rsync
5./etc/xinetd.d/rsync
# vi /etc/xinetd.d/rsync
建立一個名為/etc/xinetd.d/rsync檔案,輸入以下內容:
service rsync
{
disable = no
socket_type = stream
wait = no
user = root
server = /usr/local/rsync/bin/rsync
server_args = --daemon
log_on_failure += USERID
}
儲存後,就可以執行rsync服務了。輸入以下命令:
# /etc/rc.d/init.d/xinetd reload
這樣rsync服務就在這臺機器上(192.168.100.21)執行起來了,接下來就是如何來使用它了。
三、rsync命令的用法
在配置完rsync伺服器後,就可以從客戶端發出rsync命令來實現各種同步的操作。rsync有很
多功能選項,下面就對介紹一下常用的選項:
rsync的命令格式可以為:
1. rsync [OPTION]... SRC [SRC]... [USER@]HOST : DEST]
2. rsync [OPTION]... [USER@]HOST:SRC DEST]
3. rsync [OPTION]... SRC [SRC]... DEST]
4. rsync [OPTION]... [USER@]HOST::SRC [DEST]
5. rsync [OPTION]... SRC [SRC]... [USER@]HOST :: DEST]
6. rsync [OPTION]... rsync://[USER@]HOST[:PORT]/SRC [DEST]
rsync有六種不同的工作模式:
1. 拷貝本地檔案;當SRC和DES路徑資訊都不包含有單個冒號":"分隔符時就啟動這種工作模式。
2.使用一個遠端shell程式(如rsh、ssh)來實現將本地機器的內容拷貝到遠端機器。當DST
路徑地址包含單個冒號":"分隔符時啟動該模式。
3.使用一個遠端shell程式(如rsh、ssh)來實現將遠端機器的內容拷貝到本地機器。當SRC
地址路徑包含單個冒號":"分隔符時啟動該模式。
4. 從遠端rsync伺服器中拷貝檔案到本地機。當SRC路徑資訊包含"::"分隔符時啟動該模式。
5. 從本地機器拷貝檔案到遠端rsync伺服器中。當DST路徑資訊包含"::"分隔符時啟動該模式。
6. 列遠端機的檔案列表。這類似於rsync傳輸,不過只要在命令中省略掉本地機資訊即可。
下面以例項來說明:
# rsync -vazu -progress terry@192.168.100.21:/terry/ /home
v詳細提示
a以archive模式操作,複製目錄、符號連線
z壓縮
u只進行更新,防止本地新檔案被重寫,注意兩者機器的時鐘的同時
-progress指顯示
以上命令是保持客戶機192.168.100.90上的/home/terry目錄和rsync伺服器上的terry目錄同
步。該命令執行同步之前會要求你輸入terry賬號的密碼,這個賬號是我們前面在rsyncd.secrets
檔案中定義的。如果想將這條命令寫到一個指令碼中,然後定時執行它的話,可以使用--password-file
選項,具體命令如下:
# rsync -vazu -progress --password-file=/etc/rsync.secret
terry@192.168.100.21:/terry/ /home
要使用--password-file選項,就得先建立一個存放密碼的檔案,這裡指定為/etc/rsync.secret。
其內容很簡單,如下:
terry:12345
同樣要修改檔案屬性如下:
# chmod 600 /etc/rsyncd.secrets
四、利用rsync保持Linux伺服器間的檔案同步例項
現在假設有兩臺Linux伺服器A(192.168.100.21)和B(192.168.100.90),伺服器A中的
/home/terry和伺服器B中的/home/terry這兩個目錄需要保持同步,也就是當伺服器A中檔案發生
改變後,伺服器B中的檔案也要對應去改變。
我們按上面的方法,在伺服器A上安裝rsync,並將其配置為一臺rsync伺服器,並將/home/terry
目錄配置成rsync共享出的目錄。然後在伺服器B上安裝rsync,因為B只做客戶端,所以無需配置。
然後在伺服器B,建立以下指令碼:
#!/bin/bash
/usr/loca/rsync/bin/rsync -vazu -progress --delete
--password-file=/etc/rsync.secret terry@192.168.100.21:/terry/ /home
將這個指令碼儲存為AtoB.sh,並加上可執行屬性:
# chmod 755 /root/AtoB.sh
然後,通過crontab設定,讓這個指令碼每30分鐘執行一次。執行命令:
# crontab -e
輸入以下一行:
0,30 * * * * /root/AtoB.sh
儲存退出,這樣伺服器B每個小時的0分和30分時都會自動執行一次AtoB.sh,AtoB.sh是負責
保持伺服器B和伺服器A同步的。這樣就保證了伺服器A的所有更新在30鍾後,伺服器B也一樣取
得了和伺服器A一樣的最新的資料。
五、其它應用
rsync除了同步檔案及目錄之外,還可以利用它來實現對遠端網站的遠端備份。如果再結合指令碼和Crontab就能實現定時自動遠端備份。其可以實現與商業化的備份和鏡象產品的類似效果,但完全免費。
附:rsync有六種不同的工作模式:
1. 拷貝本地檔案;當SRC和DES路徑資訊都不包含有單個冒號":"分隔符時就啟動這種工作模式。
2.使用一個遠端shell程式(如rsh、ssh)來實現將本地機器的內容拷貝到遠端機器。當DST
路徑地址包含單個冒號":"分隔符時啟動該模式。
3.使用一個遠端shell程式(如rsh、ssh)來實現將遠端機器的內容拷貝到本地機器。當SRC
地址路徑包含單個冒號":"分隔符時啟動該模式。
4. 從遠端rsync伺服器中拷貝檔案到本地機。當SRC路徑資訊包含"::"分隔符時啟動該模式。
5. 從本地機器拷貝檔案到遠端rsync伺服器中。當DST路徑資訊包含"::"分隔符時啟動該模式。
6. 列遠端機的檔案列表。這類似於rsync傳輸,不過只要在命令中省略掉本地機資訊即可。