使用rsync來(lái)實(shí)現(xiàn)文件同步
更新時(shí)間:2008年09月17日 13:12:43 作者:
先對(duì)這個(gè)dd進(jìn)行簡(jiǎn)介,當(dāng)你的網(wǎng)站訪問(wèn)量大了,一臺(tái)服務(wù)器承受不住了
那好,這個(gè)時(shí)候,rsync來(lái)了。
rsync ->>> remote synchronize
呵呵,不用解釋了吧,還是解釋一下吧,文件同步的意思的說(shuō)。。。
第一步,先來(lái)下載這個(gè)免費(fèi)的軟件。
rsync.samba.org/ 或者 samba.anu.edu.au/rsync
本站最新版本下載地址
http://www.dhdzp.com/softs/2149.html
PS:一定要去官方網(wǎng)站下載最新的版本,
因?yàn)?.6.1之前的版本有配置模塊路徑穿越漏洞。。。
解壓縮后,編譯很簡(jiǎn)單
./configure –prefix=/usr/local/rsync && make && make install
然后先來(lái)配置服務(wù)端吧
先來(lái)編輯服務(wù)端配置文件
#vi /etc/rsyncd.conf
#全局配置
uid = root
gid = root
hosts allow = 192.168.0.0/24
#hosts deny = 0.0.0.0/32
use chroot = no # 不使用chroot
max connections = 10 # 最大連接數(shù)為10
#motd file = /etc/rsyncd.motd #歡迎信息文件名稱和存放位置(此文件沒(méi)有,可以自行添加)
pid file = /var/run/rsyncd.pid #指定rsync的pid文件
lock file = /var/run/rsync.lock #指定支持max connections參數(shù)的鎖文件,默認(rèn)值是/var/run/rsyncd.lock
log file = /var/log/rsyncd.log #指定rsync的日志文件,而不將日志發(fā)送給syslog
#下面就是每個(gè)模塊的配置了
[rsync_module_name1] # 這里是認(rèn)證的模塊名,在client端需要指定
path = /rsync_path/dir1 # 需要做鏡像的目錄
comment = rsync files
ignore errors # 可以忽略一些無(wú)關(guān)的IO錯(cuò)誤
read only = yes # 只讀
list = no # 不允許列文件
auth users = rsync_user # 認(rèn)證的用戶名,如果沒(méi)有這行,則表明是匿名,多個(gè)用戶用,分隔
secrets file = /etc/rsyncd.pas # 認(rèn)證文件名
#pid file = /var/run/rsyncd.pid
#log file = /var/log/rsyncd.log
#lock file = /var/run/rsync.lock
[rsync_module_name2]
……
其中,個(gè)人認(rèn)為,沒(méi)項(xiàng)配置都可以既在全局配置,也可以在模塊內(nèi)部配置,其中如果模塊內(nèi)部如果有與全局相同的配置,
則模塊內(nèi)部的配置覆蓋全局的配置。
然后編輯你上面指定的認(rèn)證文件,我這里是: /etc/rsyncd.pas
#vi /etc/rsyncd.pas
格式為: username:password
rsync_user:rsyncofpass
安全起見(jiàn),更改認(rèn)證文件屬性
#chmod 0600 /etc/rsyncd.pas
ok,現(xiàn)在啟動(dòng)下試試看吧。
#/usr/local/rsync/bin/rsync –daemon
你也可以指定rsync運(yùn)行的端口
#/usr/local/rsync/bin/rsync –daemon –port=873
如果要在啟動(dòng)時(shí)把服務(wù)起來(lái),有幾種不同的方法,比如:
加入inetd.conf
編輯/etc/services,加入rsync 873/tcp,指定rsync的服務(wù)端口是873
編輯/etc/inetd.conf,加入rsync stream tcp nowait root /bin/rsync rsync –daemon
加入rc.local
在各種操作系統(tǒng)中,rc文件存放位置不盡相同,可以修改使系統(tǒng)啟動(dòng)時(shí)rsync –daemon加載進(jìn)去。
我這里是直接加入 /etc/rc.local
/usr/local/rsync/bin/rsync –daemon –port=873
873就是rsync的默認(rèn)端口號(hào)。
記得配置防火墻,允許你rsync端口的tcp和udp協(xié)議。
873:tcp 873:udp
下面開(kāi)始配置客戶端
下面這個(gè)命令行中-vzrtopg里的v是verbose,
z是壓縮傳輸,
r是recursive,
topg都是保持文件原有屬性如屬主、時(shí)間的參數(shù)。
u是只同步已經(jīng)更新的文件,避免沒(méi)有更新的文件被重復(fù)更新一次,不過(guò)要注意兩者機(jī)器的時(shí)鐘的同步。
–progress是指顯示出詳細(xì)的進(jìn)度情況,
–delete是指如果服務(wù)器端刪除了這一文件,那么客戶端也相應(yīng)把文件刪除,保持真正的一致。
后面的rsync_user@192.168.0.2::rsync_module_name1中,之后的rsync_module_name1是模塊名,也就是在/etc/rsyncd.conf中自定義的名稱,rsync_user是指定模塊中指定的可以同步的用戶名。
最后的/tmp是備份到本地的目錄名。
在這里面,還可以用-e ssh的參數(shù)建立起加密的連接。
可以用–password-file=/password/path/file來(lái)指定密碼文件,這樣就可以在腳本中使用而無(wú)需交互式地輸入驗(yàn)證密碼了,這里需要注意的是這份密碼文件權(quán)限屬性要設(shè)得只有屬主可讀。
#/usr/local/rsync/bin/rsync -vzrtopg –progress –delete rsync_user@192.168.0.2::rsync_module_name1 /tmp/
Password:
或者你也可以制定password文件
由于需要系統(tǒng)crontab執(zhí)行,所以這里采用讀入密碼文件的方式,
這個(gè)時(shí)候就成功了。
#vi /etc/rsyncd.pas
加入
rsync_user:rsyncofpass
注意,客戶端的密碼文件只需要密碼,而不需要用戶名!
rsyncofpass
更改文件權(quán)限:
#chmod 0600 /etc/rsyncd.pas
#/usr/local/rsync/bin/rsync -vzrtopgu –progress –delete –password-file=/etc/rsyncd.pas rsync_user@192.168.0.2::rsync_module_name1 /tmp/
不知道為什么,總是提示下面的認(rèn)證錯(cuò)誤
@ERROR: auth failed on module rsync_module_name1
rsync error: error starting client-server protocol (code 5) at main.c(1383) [receiver=2.6.9]
郁悶了,怎么都搞不定,還希望有經(jīng)驗(yàn)的朋友給提供一下支持。。。
在今天在客戶端密碼文件只輸入密碼后,終于成功了
以后有時(shí)間再研究認(rèn)證問(wèn)題吧,時(shí)間緊,任務(wù)急,把驗(yàn)證先繞過(guò)。
呵呵,不用解釋了吧,還是解釋一下吧,文件同步的意思的說(shuō)。。。
第一步,先來(lái)下載這個(gè)免費(fèi)的軟件。
rsync.samba.org/ 或者 samba.anu.edu.au/rsync
本站最新版本下載地址
http://www.dhdzp.com/softs/2149.html
PS:一定要去官方網(wǎng)站下載最新的版本,
因?yàn)?.6.1之前的版本有配置模塊路徑穿越漏洞。。。
解壓縮后,編譯很簡(jiǎn)單
./configure –prefix=/usr/local/rsync && make && make install
然后先來(lái)配置服務(wù)端吧
先來(lái)編輯服務(wù)端配置文件
#vi /etc/rsyncd.conf
#全局配置
uid = root
gid = root
hosts allow = 192.168.0.0/24
#hosts deny = 0.0.0.0/32
use chroot = no # 不使用chroot
max connections = 10 # 最大連接數(shù)為10
#motd file = /etc/rsyncd.motd #歡迎信息文件名稱和存放位置(此文件沒(méi)有,可以自行添加)
pid file = /var/run/rsyncd.pid #指定rsync的pid文件
lock file = /var/run/rsync.lock #指定支持max connections參數(shù)的鎖文件,默認(rèn)值是/var/run/rsyncd.lock
log file = /var/log/rsyncd.log #指定rsync的日志文件,而不將日志發(fā)送給syslog
#下面就是每個(gè)模塊的配置了
[rsync_module_name1] # 這里是認(rèn)證的模塊名,在client端需要指定
path = /rsync_path/dir1 # 需要做鏡像的目錄
comment = rsync files
ignore errors # 可以忽略一些無(wú)關(guān)的IO錯(cuò)誤
read only = yes # 只讀
list = no # 不允許列文件
auth users = rsync_user # 認(rèn)證的用戶名,如果沒(méi)有這行,則表明是匿名,多個(gè)用戶用,分隔
secrets file = /etc/rsyncd.pas # 認(rèn)證文件名
#pid file = /var/run/rsyncd.pid
#log file = /var/log/rsyncd.log
#lock file = /var/run/rsync.lock
[rsync_module_name2]
……
其中,個(gè)人認(rèn)為,沒(méi)項(xiàng)配置都可以既在全局配置,也可以在模塊內(nèi)部配置,其中如果模塊內(nèi)部如果有與全局相同的配置,
則模塊內(nèi)部的配置覆蓋全局的配置。
然后編輯你上面指定的認(rèn)證文件,我這里是: /etc/rsyncd.pas
#vi /etc/rsyncd.pas
格式為: username:password
rsync_user:rsyncofpass
安全起見(jiàn),更改認(rèn)證文件屬性
#chmod 0600 /etc/rsyncd.pas
ok,現(xiàn)在啟動(dòng)下試試看吧。
#/usr/local/rsync/bin/rsync –daemon
你也可以指定rsync運(yùn)行的端口
#/usr/local/rsync/bin/rsync –daemon –port=873
如果要在啟動(dòng)時(shí)把服務(wù)起來(lái),有幾種不同的方法,比如:
加入inetd.conf
編輯/etc/services,加入rsync 873/tcp,指定rsync的服務(wù)端口是873
編輯/etc/inetd.conf,加入rsync stream tcp nowait root /bin/rsync rsync –daemon
加入rc.local
在各種操作系統(tǒng)中,rc文件存放位置不盡相同,可以修改使系統(tǒng)啟動(dòng)時(shí)rsync –daemon加載進(jìn)去。
我這里是直接加入 /etc/rc.local
/usr/local/rsync/bin/rsync –daemon –port=873
873就是rsync的默認(rèn)端口號(hào)。
記得配置防火墻,允許你rsync端口的tcp和udp協(xié)議。
873:tcp 873:udp
下面開(kāi)始配置客戶端
下面這個(gè)命令行中-vzrtopg里的v是verbose,
z是壓縮傳輸,
r是recursive,
topg都是保持文件原有屬性如屬主、時(shí)間的參數(shù)。
u是只同步已經(jīng)更新的文件,避免沒(méi)有更新的文件被重復(fù)更新一次,不過(guò)要注意兩者機(jī)器的時(shí)鐘的同步。
–progress是指顯示出詳細(xì)的進(jìn)度情況,
–delete是指如果服務(wù)器端刪除了這一文件,那么客戶端也相應(yīng)把文件刪除,保持真正的一致。
后面的rsync_user@192.168.0.2::rsync_module_name1中,之后的rsync_module_name1是模塊名,也就是在/etc/rsyncd.conf中自定義的名稱,rsync_user是指定模塊中指定的可以同步的用戶名。
最后的/tmp是備份到本地的目錄名。
在這里面,還可以用-e ssh的參數(shù)建立起加密的連接。
可以用–password-file=/password/path/file來(lái)指定密碼文件,這樣就可以在腳本中使用而無(wú)需交互式地輸入驗(yàn)證密碼了,這里需要注意的是這份密碼文件權(quán)限屬性要設(shè)得只有屬主可讀。
#/usr/local/rsync/bin/rsync -vzrtopg –progress –delete rsync_user@192.168.0.2::rsync_module_name1 /tmp/
Password:
或者你也可以制定password文件
由于需要系統(tǒng)crontab執(zhí)行,所以這里采用讀入密碼文件的方式,
這個(gè)時(shí)候就成功了。
#vi /etc/rsyncd.pas
加入
rsync_user:rsyncofpass
注意,客戶端的密碼文件只需要密碼,而不需要用戶名!
rsyncofpass
更改文件權(quán)限:
#chmod 0600 /etc/rsyncd.pas
#/usr/local/rsync/bin/rsync -vzrtopgu –progress –delete –password-file=/etc/rsyncd.pas rsync_user@192.168.0.2::rsync_module_name1 /tmp/
不知道為什么,總是提示下面的認(rèn)證錯(cuò)誤
@ERROR: auth failed on module rsync_module_name1
rsync error: error starting client-server protocol (code 5) at main.c(1383) [receiver=2.6.9]
郁悶了,怎么都搞不定,還希望有經(jīng)驗(yàn)的朋友給提供一下支持。。。
在今天在客戶端密碼文件只輸入密碼后,終于成功了
以后有時(shí)間再研究認(rèn)證問(wèn)題吧,時(shí)間緊,任務(wù)急,把驗(yàn)證先繞過(guò)。
您可能感興趣的文章:
- Rsync命令參數(shù)詳解
- rsync 安裝使用詳解
- rsync 同步錯(cuò)誤 cwrsync rsync error rsync error: some files/attrs were not transferred 解決方法
- rsync?常見(jiàn)錯(cuò)誤與解決方法整理
- 用rsync實(shí)現(xiàn)windows與linux文件同步的方法
- RsyncServer服務(wù)無(wú)法啟動(dòng)的解決方法
- 用rsync對(duì)網(wǎng)站進(jìn)行鏡像備份步驟
- 利用rsync自動(dòng)備份 完全配置方法 增加了ip限制
- Windows rsync服務(wù)器備份配置實(shí)例
- window系統(tǒng)的Rsync同步實(shí)戰(zhàn)分析
- windows下rsync的數(shù)據(jù)同步安裝配置方法
- cwrsync實(shí)現(xiàn)從linux到windows的數(shù)據(jù)同步備份
相關(guān)文章
Windows Server 2008 R2 下配置TLS1.2添加自簽名證書(shū)的圖文教程
這篇文章主要介紹了Windows Server 2008 R2 下配置TLS1.2添加自簽名證書(shū)的圖文教程,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2016-12-12
IIS 應(yīng)用程序池自動(dòng)關(guān)閉的解決辦法
訪問(wèn)站點(diǎn)。會(huì)導(dǎo)致應(yīng)用程序池自動(dòng)關(guān)閉,而出現(xiàn)Service Unavailable的提示。在允許和禁止一些WEB服務(wù)擴(kuò)展時(shí)會(huì)提示MMC有錯(cuò)誤。2009-06-06
win2003 administrator 內(nèi)置系統(tǒng)管理員賬號(hào)名稱修改方法
為了安全考慮,我們的服務(wù)器一般都將administrator改名,這個(gè)可以一定程度上,躲過(guò)黑客的暴力拆解。2009-08-08
關(guān)于訪問(wèn)IIS元數(shù)據(jù)庫(kù)失敗的解決方法
近日調(diào)試一Asp.net程序,出現(xiàn)了“訪問(wèn) IIS 元數(shù)據(jù)庫(kù)失敗”的錯(cuò)誤信息,最后經(jīng)過(guò)搜索發(fā)現(xiàn)了解決問(wèn)題的方法2013-04-04
Windows服務(wù)器安裝PHP MongoDB擴(kuò)展的方法
這篇文章主要介紹了Windows服務(wù)器安裝PHP MongoDB擴(kuò)展的方法,需要的朋友可以參考下2016-11-11
Windows Server 2019安裝域控制器(圖文教程)
本文主要介紹了Windows Server 2019安裝域控制器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
將IIS Express改成可以通過(guò)ip地址訪問(wèn)的設(shè)置方法
通過(guò)瀏覽器訪問(wèn)的是localhost,如果通過(guò)手機(jī)訪問(wèn)則需要用ip地址,所以要修改IIS Express的配置,允許通過(guò)ip地址訪問(wèn),需要的朋友可以參考下2023-06-06
Windows IIS配置Jsp和php環(huán)境方法
我們一般將Tomcat與Apache或IIS配合使用,讓Apache對(duì)網(wǎng)站的靜態(tài)頁(yè)面請(qǐng)求提供服務(wù),而Tomcat作為專用的JSP引擎,提供JSP解析,以得到更好的性能。2009-06-06

