故事背景:我們公司是做新零售的,需要對發布的每臺機器進行檔案的同步更新,所以我這里做了一個小小的調研
技術調研:linux之間同步檔案有兩種方式rsync與scp,
sync和scp在檔案夾均不存在時,執行時間相差不大,但是檔案夾存在的情況下差異很大,原因是scp是復制:若mas2檔案不存在則新建,若存在則覆寫,若mas2上有而Dashboard主機沒有,則不改變,可以理解為scp為“復制”,而rsync則在檔案在存在于兩主機時,比較兩檔案是夠相同,相同的話,就什么都不做,若存在差異就直接更新,
簡單的說rsync只對差異檔案做更新,
#### Rsync介紹
rsync是一款開源的備份工具,可以再不同主機之間進行同步,實作全量和增量備份,適用于集中備份或異地備份等應用場景,
rsync監聽埠:873
rsync運行模式:C/S
#### Rsync傳輸模式
- 本地模式
本地傳輸,主機內部進行資料傳輸(類似于cp命令)
- 遠程模式
遠程通道傳輸,通過ssh通道傳輸資料(類似scp命令)
- 守護行程模式
守護行程傳輸,不使用系統用戶進行傳輸(安全性高)
#### Rsync命令引數
-a 復制各種型別的檔案(相當于-tropgDl)
-v 顯示傳輸程序
-z 傳輸時進行壓縮
-r 遞回傳輸目錄和子目錄
-t 保持檔案時間不變
-o 保持檔案屬主資訊
-g 保持檔案屬組資訊
-p 保持檔案權限
-l 保持軟連接
-P 顯示同步進度及程序
-D 保持設備檔案資訊
--bwlimit=100 限速傳輸
--delete 源和目標資料保持一致
--partial 斷點續傳
#### 安裝rsync
`sudo apt-get install`一般機器好像都有
#### 服務端
1. 創建rsyncd.conf組態檔,sudo vim /etc/rsyncd.conf
`uid = ai #運行行程用戶
gid = ai #運行用戶組
port = 873 #監聽埠
fake super = yes #無需rsync以root身份運行,允許接受資料
use chroot = no #禁錮推送資料至某個目錄
max connections = 0 #最大連接數
timeout = 600 #超時時間
log file = /var/log/rsyncd.log #定義日志檔案路徑
#####################################
[backup] #模塊名稱
path = /backup #定義接收備份資料目錄
ignore errors #忽略錯誤資訊
read only = false #對備份資料可讀寫
list = false #不允許查看模塊資訊
auth users = test #定義虛擬用戶,認證使用
secrets file = /etc/rsync.passwd #認證密碼路徑`
2. 創建rsync.passwd
`echo "test:123456" > /etc/rsync.passwd
chmod 600 /etc/rsync.passwd 不然傳輸會報錯`
3. 啟動rsync
`rsync --daemon`
#### 客戶端
1. 創建rsync.passwd
`echo "123456" > /etc/rsync.password
chmod 600 /etc/rsync.password 不然傳輸會報錯`
#### 實體(拉取)
`rsync -avz [email protected]::backup --password-file=/etc/rsyncd.password /tmp/backup/`
#### 定時拉取
把拉取指令配置在客戶端crontab即可
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/156781.html
標籤:Linux
上一篇:Linux上安裝nginx
下一篇:網路時間服務和chrony
