linux/centos rsync安裝配置(zhì)教程(實測通過)
一、服務器端配置:
# yum -y install xinetd
# vi /etc/xinetd.d/rsync
將如下代碼
service rsync
{
disable = yes
socket_type = stream
wait = no
user = root
server = /usr/bin/rsync
server_args = –daemon
log_on_failure += USERID
}
中的 disable = yes 改成 disable = no
然後啟動 xinetd
# /etc/init.d/xinetd start 或 service xinetd restart
注意:如果服務器上裝有防火牆(qiáng)記得要打開端口,默認端口是873
# telnet 127.0.0.1 873
Trying 127.0.0.1...
telnet: connect to address 127.0.0.1: Connection refused
# iptables -A INPUT -s 192.168.0.0/255.255.255.0 -p tcp -m tcp --dport 873 -j ACCEPT
# iptables -A INPUT -p tcp -m tcp --dport 873 -j DROP
# vi /etc/rsyncd.conf (這個文件如果不存在自己創建)
#Global Settings
uid = root #以什麽身份運(yùn)行rsync
gid = root
use chroot = no #不使用chroot
max connections = 20 #最大連接數
secrets file = /etc/rsyncd.secrets #密碼(mǎ)文件(jiàn)位置,認證文件設(shè)置,設置用(yòng)戶名和密碼
log file = /var/log/rsyncd.log #指定rsync的日誌文件,而(ér)不將日誌發送給syslog
pid file = /var/run/rsyncd.pid #指定rsync的(de)pid文件
lock file = /var/run/rsync.lock #指定支持(chí)max connections參數的鎖文件,默認值是/var/run/rsyncd.lock
comment = hello world
#motd file = /etc/rsyncd.motd #歡迎信息文件名稱和存放位置(此文件沒(méi)有,可以(yǐ)自行添加)
[backup] # 這裏是(shì)認證的模塊名,在client端需要指定
path = /titan24/www/repos # 需要做鏡像的(de)目錄
auth users = rsync # 授權帳號。認證的用戶名,如果沒有這行,則表明是(shì)匿名,多個用戶用,分隔
read only = no # yes隻(zhī)讀 值為(wéi)NO意(yì)思為可讀可寫模式,數據恢複用NO
hosts allow = 192.168.3.128 #允許訪(fǎng)問的(de)服務器IP
hosts deny = * #黑名單
list = true # 允許列文(wén)件
#ignore errors # 可以忽略一些無關的IO錯誤
#exclude = cache/111/ cache/222/ #忽略的目錄
# vi /etc/rsyncd.secrets (設置訪問(認(rèn)證)的用戶名密碼)
rsync:111111 #用戶名:密(mì)碼
給文件正確的權限
# chown root:root /etc/rsyncd.secrets
# chmod 600 /etc/rsyncd.secrets
二、client 端進行同步
客戶端默認好(hǎo)像已經裝了rsync,沒有的話裝(zhuāng)下:
# yum -y install rsync
執行異(yì)步同步操作:
/usr/bin/rsync -avz --progress
# crontab -e #(可以定時每(měi)三分鍾同步(bù)一次文件)
*/3
下麵這個(gè)命令完整一點:
#vi /etc/rsyncd.pas
加入密碼
rsyncofpass
注意,客戶端的密碼文件隻需要密碼,而不需要用戶名!
更改文件權限:
#chmod 0600 /etc/rsyncd.pas
#rsync -vzrtopgu --progress --delete --password-file=/etc/rsyncd.pas
這個命令(lìng)行中-vzrtopg裏的v是verbose,
z是壓縮傳輸,
r是recursive,
topg都是保持文件原有屬性如屬主、時間的參數。
u是(shì)隻同步已經更新的文件,避免沒有更新的文件被重複更(gèng)新一次,不過要注意兩者機(jī)器的時鍾的同(tóng)步。
–progress是指顯示出詳細的進度情況,
–delete是指如果服務器端刪除了這一(yī)文件,那麽客戶端也相應把文件(jiàn)刪除,保持真正的一(yī)致。
後 麵的rsync_user@192.168.0.2::rsync_module_name1中,之後的rsync_module_name1是模塊名, 也就是(shì)在/etc/rsyncd.conf中自定義的名稱,rsync_user是指定(dìng)模(mó)塊(kuài)中指定(dìng)的可以同步的用戶名。
最後的/www是備份到本地的目錄名。
在這裏麵(miàn),還可以用-e ssh的參數建立起加密的連接。
可以用(yòng)–password-file=/password/path/file來指(zhǐ)定密碼文件,這樣(yàng)就可以在腳本中使用而無需交互式(shì)地輸入驗證(zhèng)密碼了,這裏需(xū)要注意的是這份密碼文件權限屬性要設(shè)得隻有屬主可讀。
#/usr/local/rsync/bin/rsync -vzrtopg –progress –delete rsync_user@192.168.0.2::rsync_module_name1/tmp/
Password:
或(huò)者你也(yě)可以製定password文(wén)件
由於需要係統crontab執行(háng),所以這(zhè)裏采用讀入密碼文件的方式,
這個時候就成功了。
請繼續瀏覽下一頁:同步命令說明
---------------------------------同步命令說明:---------------------------------
1 顯示(shì)目錄(lù)內容
命令
——
a) rsync
b) rsync -r
c) rsync jack@192.168.0.1::
d) rsync ssh_user@192.168.0.1:
命令說明
———
a) 顯示目錄(lù)內容(第一層)
b) 遞歸顯(xiǎn)示目錄內容(róng)
c) 顯示遠程主機目錄內(nèi)容
*注1:端(duān)口(kǒu)模式, 基於rsync用戶的身份驗證
*注2:rsync server上(shàng)的目錄必須具有xx7的權限.
d) 查看遠程主機目(mù)錄內容
*注1:remote shell模(mó)式, 通過ssh連接的基於係統本地用戶的身份驗證(zhèng)
*注2:這裏隻使用了一個冒號(:),同時用戶名是遠程主機的(de)ssh 用戶,密(mì)碼也是ssh用戶對(duì)應(yīng)的密碼。
*注(zhù)3:使用””,則列(liè)出(chū)文件夾本身的信息。若要列出文件夾內容,應使用”/”。
參(cān)數說明
———
-r 對目錄進行遞歸操作
2 本地目錄之間(jiān)同步
命令
——
a) rsync -av –progress / *** 注意(/) ***
b) rsync -av –progress
c) rsync -avu –progress –delete /
d) rsync -av –progress –temp-dir=/tmp /
命(mìng)令說明
———
a) 同步src-dir目錄(lù)下所有文件到(dào)dst-dir目錄下(xià)
b) 同(tóng)步src-dir目錄下所有(yǒu)文件到dst-dir/src-dir目錄下
c) 對src-dir目錄內容向dst-dir目錄下(xià)進行(háng)差異更新,有增加/更新則添加替換,有減少則對其刪減
d) 比a)多了–temp-dir=/tmp,即(jí)指定/tmp為臨時交換區(qū),這樣可(kě)以避免因目標目(mù)錄空間不夠引起的無法同步文件的錯誤。
參數說明
———
-a 相當於 -rlptgoD 的集合
-u 等同於 –update,在目標(biāo)文件比源文(wén)件新的情況下不(bú)更新
-v 顯示同步的文件
–progress 顯示文(wén)件同(tóng)步時的百分比進度、傳輸(shū)速(sù)率
–delete 刪除目標目錄中多於源目錄的文件
3 異地主(zhǔ)機之間同步
命令
——
a) rsync -avz –progress jack@192.168.0.1::/
b) rsync -avz –progress jack@192.168.0.1::/ –password-file=/home/jack/rsync.jack
c) rsync -avuz –progress –delete jack@192.168.0.1::/ –password-file=/home/jack/rsync.jack
d) rsync -avz –progress jack@192.168.0.1::/
命令說明
———
a) 同步本地目錄的內容(róng)到遠程主機192.168.0.1的目錄下,jack是(shì)rsync數據(jù)庫用戶(參見3. /etc/rsync.secrets)
b) 通過自動讀取用戶密碼而實現非交互登錄文件同步
c) 較b)多了-u和–delete
d) 同步遠程主機內容到本地目錄
關鍵詞:linux,centos
閱讀本文後您有什麽感想? 已有 人(rén)給出評價!
- 0
- 0
- 0
- 0
- 0
- 0