rsync Service Configuration
# vi /etc/xinetd.d/rsync
disable = yes 改成 disable = no
rsyncd.conf 是rsyncd的config文件
# vi /etc/rsyncd.conf
#uid = nobody
#gid = nobody
use chroot = yes
max connections = 4
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log
[compshop]
path = /home/sites/compshop
auth users = compshop
uid = compshop
gid = compshop
secrets file = /etc/rsyncd.secrets
read only = no
[datafeed]
path = /home/sites/datafeed
auth users = datafeed
uid = datafeed
gid = datafeed
secrets file = /etc/rsyncd.secrets
read only = no
[smtemplates]
path = /home/sites/smtemplates
auth users = smtemplates
uid = smtemplates
gid = smtemplates
secrets file = /etc/rsyncd.secrets
read only = no
[smarterv2]
path = /home/sites/smarterv2
auth users = smarterv2
uid = smarterv2
gid = smarterv2
secrets file = /etc/rsyncd.secrets
read only = no
rsyncd.secrets是rsyncd的密碼文件,裏面是寫用戶名和密碼,就是linux的用戶名和密碼
# vi /etc/rsyncd.secrets
compshop:any
datafeed:any
smtemplates:any
smarterv2:any
以上是服務器端的配置,開了這個服務以後,端口是873;
以下是客服端的配置文件,是在另外一臺電腦上的,文件名是可以自己改的。
# vi /home/sites/sites_rsyncd
#!/bin/bash
rsync -tvzrp --progress --password-file=/home/sites/rsyncd.secrets --delete --exclude /home/sites/compshop/logs
[email protected]::compshop /home/sites/compshop/
rsync -tvzrp --progress --password-file=/home/sites/rsyncd.secrets --delete --exclude /home/sites/datafeed/logs [email protected]::datafeed /home/sites/datafeed/
rsync -tvzrp --progress --password-file=/home/sites/rsyncd.secrets --delete --exclude /home/sites/smtemplates/logs [email protected]::smtemplates /home/sites/smtemplates/
rsync -tvzrp --progress --password-file=/home/sites/rsyncd.secrets --delete --exclude /home/sites/smarterv2/logs [email protected]::smarterv2 /home/sites/smarterv2/
# chmod 744 /home/sites/sites_rsyncd
# vi /home/sites/rsyncd.secrets
any
# chmod 600 /home/sites/rsyncd.secrets
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 [email protected]:/user01/ /home
-v 詳細提示
-a 以archive模式操作,複製目錄、符號連接
-z 壓縮
-u 只進行更新,防止本地新文件被重寫,注意兩者機器的時鐘的同時
-progress 指顯示
以上命令是保持客戶機上的/home/user01目錄和rsync服務器上的user01目錄同步。該命令執行同步之前會要求你輸入terry賬號的密碼,這個賬號是我們前面在rsyncd.secrets文件中定義的。如果想將這條命令寫到一個腳本中,然後定時執行它的話,可以使用--password-file選項,具體命令如下:
# rsync -vazu -progress --password-file=/etc/rsync.secret [email protected]:/user01/ /home
要使用--password-file選項,就得先建立一個存放密碼的文件,這裏指定爲/etc/rsync.secret,其內容很簡單,如下:
user01:123456
同樣要修改文件屬性如下:
# chmod 600 /etc/rsyncd.secrets
利用rsync保持Linux服務器間的文件同步實例
現在假設有兩臺Linux服務器A(192.168.1.2)和B(192.168.1.9),服務器A中的/home/user01和服務器B中的/home/uesr01這兩個目錄需要保持同步,也就是當服務器A中文件發生改變後,服務器B中的文件也要對應去改變。
我們按上面的方法,在服務器A上安裝rsync,並將其配置爲一臺rsync服務器,並將/home/user01目錄配置成rsync共享出的目錄。然後在服務器B上安裝rsync,因爲B只做客戶端,所以無需配置。然後在服務器B,建立以下腳本:
#!/bin/bash
/usr/loca/rsync/bin/rsync -vazu -progress --delete --password-file=/etc/rsync.secret
[email protected]:/user01/ /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一樣的最新的資料。