Centos rsync文件同步配置步驟分享
rsync是類unix系統(tǒng)下的數(shù)據(jù)鏡像備份工具,從軟件的命名上就可以看出來了——remote sync
它的特性如下:
可以鏡像保存整個目錄樹和文件系統(tǒng)。
可以很容易做到保持原來文件的權(quán)限、時間、軟硬鏈接等等。
無須特殊權(quán)限即可安裝。
快速:第一次同步時 rsync 會復(fù)制全部內(nèi)容,但在下一次只傳輸修改過的文件。rsync 在傳輸數(shù)據(jù)的過程中可以實行壓縮及解壓縮操作,因此可以使用更少的帶寬。
安全:可以使用scp、ssh等方式來傳輸文件,當(dāng)然也可以通過直接的socket連接。
支持匿名傳輸,以方便進行網(wǎng)站鏡象。
一、服務(wù)器端配置:
# 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
注意:如果服務(wù)器上裝有防火墻記得要打開端口,默認端口是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 (這個文件如果不存在自己創(chuàng)建)
uid = root #以什么身份運行rsync
gid = root
use chroot = no #不使用chroot
max connections = 20 #最大連接數(shù)
secrets file = /etc/rsyncd.secrets #密碼文件位置,認證文件設(shè)置,設(shè)置用戶名和密碼
log file = /var/log/rsyncd.log #指定rsync的日志文件,而不將日志發(fā)送給syslog
pid file = /var/run/rsyncd.pid #指定rsync的pid文件
lock file = /var/run/rsync.lock #指定支持max connections參數(shù)的鎖文件,默認值是/var/run/rsyncd.lock
comment = hello world
#motd file = /etc/rsyncd.motd #歡迎信息文件名稱和存放位置(此文件沒有,可以自行添加)
[backup] # 這里是認證的模塊名,在client端需要指定
path = /titan24/www/repos # 需要做鏡像的目錄
auth users = rsync # 授權(quán)帳號。認證的用戶名,如果沒有這行,則表明是匿名,多個用戶用,分隔
read only = no # yes只讀 值為NO意思為可讀可寫模式,數(shù)據(jù)恢復(fù)用NO
hosts allow = 192.168.3.128 #允許訪問的服務(wù)器IP
hosts deny = * #黑名單
list = true # 允許列文件
#ignore errors # 可以忽略一些無關(guān)的IO錯誤
#exclude = cache/111/ cache/222/ #忽略的目錄
# vi /etc/rsyncd.secrets (設(shè)置訪問(認證)的用戶名密碼)
給文件正確的權(quán)限
# chown root:root /etc/rsyncd.secrets
# chmod 600 /etc/rsyncd.secrets
二、client 端進行同步
客戶端默認好像已經(jīng)裝了rsync,沒有的話裝下:
# yum -y install rsync
執(zhí)行異步同步操作:
/usr/bin/rsync -avz --progress
# crontab -e #(可以定時每三分鐘同步一次文件)
下面這個命令完整一點:
#vi /etc/rsyncd.pas
加入密碼
rsyncofpass
注意,客戶端的密碼文件只需要密碼,而不需要用戶名!
更改文件權(quán)限:
#chmod 0600 /etc/rsyncd.pas
#rsync -vzrtopgu --progress --delete --password-file=/etc/rsyncd.pas
這個命令行中-vzrtopg里的v是verbose,
z是壓縮傳輸,
r是recursive,
topg都是保持文件原有屬性如屬主、時間的參數(shù)。
u是只同步已經(jīng)更新的文件,避免沒有更新的文件被重復(fù)更新一次,不過要注意兩者機器的時鐘的同步。
–progress是指顯示出詳細的進度情況,
–delete是指如果服務(wù)器端刪除了這一文件,那么客戶端也相應(yīng)把文件刪除,保持真正的一致。
后 面的rsync_user@192.168.0.2::rsync_module_name1中,之后的rsync_module_name1是模塊名, 也就是在/etc/rsyncd.conf中自定義的名稱,rsync_user是指定模塊中指定的可以同步的用戶名。
最后的/www是備份到本地的目錄名。
在這里面,還可以用-e ssh的參數(shù)建立起加密的連接。
可以用–password-file=/password/path/file來指定密碼文件,這樣就可以在腳本中使用而無需交互式地輸入驗證密碼了,這里需要注意的是這份密碼文件權(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í)行,所以這里采用讀入密碼文件的方式,
這個時候就成功了。
同步命令說明:
1 顯示目錄內(nèi)容
命令
——
a) rsync
b) rsync -r
c) rsync jack@192.168.0.1::
d) rsync ssh_user@192.168.0.1:
命令說明
———
a) 顯示目錄內(nèi)容(第一層)
b) 遞歸顯示目錄內(nèi)容
c) 顯示遠程主機目錄內(nèi)容
*注1:端口模式, 基于rsync用戶的身份驗證
*注2:rsync server上的目錄必須具有xx7的權(quán)限.
d) 查看遠程主機目錄內(nèi)容
*注1:remote shell模式, 通過ssh連接的基于系統(tǒng)本地用戶的身份驗證
*注2:這里只使用了一個冒號(:),同時用戶名是遠程主機的ssh 用戶,密碼也是ssh用戶對應(yīng)的密碼。
*注3:使用””,則列出文件夾本身的信息。若要列出文件夾內(nèi)容,應(yīng)使用”/”。
參數(shù)說明
———
-r 對目錄進行遞歸操作
2 本地目錄之間同步
命令
——
a) rsync -av –progress / *** 注意(/) ***
b) rsync -av –progress
c) rsync -avu –progress –delete /
d) rsync -av –progress –temp-dir=/tmp /
命令說明
———
a) 同步src-dir目錄下所有文件到dst-dir目錄下
b) 同步src-dir目錄下所有文件到dst-dir/src-dir目錄下
c) 對src-dir目錄內(nèi)容向dst-dir目錄下進行差異更新,有增加/更新則添加替換,有減少則對其刪減
d) 比a)多了–temp-dir=/tmp,即指定/tmp為臨時交換區(qū),這樣可以避免因目標(biāo)目錄空間不夠引起的無法同步文件的錯誤。
參數(shù)說明
———
-a 相當(dāng)于 -rlptgoD 的集合
-u 等同于 –update,在目標(biāo)文件比源文件新的情況下不更新
-v 顯示同步的文件
–progress 顯示文件同步時的百分比進度、傳輸速率
–delete 刪除目標(biāo)目錄中多于源目錄的文件
3 異地主機之間同步
命令
——
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) 同步本地目錄的內(nèi)容到遠程主機192.168.0.1的目錄下,jack是rsync數(shù)據(jù)庫用戶(參見3. /etc/rsync.secrets)
b) 通過自動讀取用戶密碼而實現(xiàn)非交互登錄文件同步
c) 較b)多了-u和–delete
d) 同步遠程主機內(nèi)容到本地目錄
相關(guān)文章
systemd添加自定義系統(tǒng)服務(wù)設(shè)置自定義開機啟動的方法
下面小編就為大家?guī)硪黄猻ystemd添加自定義系統(tǒng)服務(wù)設(shè)置自定義開機啟動的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12
一文詳解Linux三種網(wǎng)絡(luò)設(shè)置方式
我們在使用虛擬機搭建linux系統(tǒng)后,常常需要設(shè)置系統(tǒng)網(wǎng)絡(luò)連接,以方便系統(tǒng)進行上網(wǎng)或其他系統(tǒng)連接系統(tǒng)進行操作,在linux中網(wǎng)絡(luò)連接分了三類:橋接模式,僅主機模式,NAT模式,本文我們將對這三種模式進行講解,感興趣的同學(xué)可以參考閱讀2023-06-06
Windows 和 Linux 上Redis的安裝守護進程配置方法
​ Redis是目前最常用的非關(guān)系型數(shù)據(jù)庫(NOSql)之一,常以Key-Value的形式存儲。這篇文章主要介紹了Windows 和 Linux 上Redis的安裝守護進程配置 ,需要的朋友可以參考下2019-06-06
Ubuntu20.04 VNC 安裝與設(shè)置實現(xiàn)
這篇文章主要介紹了Ubuntu20.04 VNC 安裝與設(shè)置實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
Linux用戶建立腳本/猜字游戲/網(wǎng)卡流量監(jiān)控介紹
大家好,本篇文章主要講的是Linux用戶建立腳本/猜字游戲/網(wǎng)卡流量監(jiān)控介紹,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下2021-12-12
Ubuntu基礎(chǔ)設(shè)定:openssh-server的安裝和使用介紹
今天小編就為大家分享一篇關(guān)于Ubuntu基礎(chǔ)設(shè)定:openssh-server的安裝和使用介紹,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-01-01

