Rsync實現文件的同步

来源:https://www.cnblogs.com/xupeidong/archive/2019/11/12/11840621.html
-Advertisement-
Play Games

故事背景:我們公司是做新零售的,需要對發佈的每台機器進行文件的同步更新,所以我這裡做了一個小小的調研 技術調研:linux之間同步文件有兩種方式rsync與scp。 sync和scp在文件夾均不存在時,執行時間相差不大,但是文件夾存在的情況下差異很大。原因是scp是複製:若mas2文件不存在則新建, ...


故事背景:我們公司是做新零售的,需要對發佈的每台機器進行文件的同步更新,所以我這裡做了一個小小的調研

 

技術調研: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即可


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 畢業已有半年, 現在想想真的後悔, 大學沒有認真學Linux, 導致現在Linux操作抓瞎, 連伺服器都搭不起來。 下定決心重學Linux, 不追求能比上大佬, 但是要熟練, 常用命令要熟悉。 作為一項輔助技能,夠用就好。 ...
  • ftp工具無法連接Linux伺服器,文件無法上傳,是因為你的ftp伺服器未搭建(或未啟動) 許久沒有登錄騰訊雲,今天想用xshell的xftp工具上傳文件,卻突然出現連接不上。 用22埠,可以正常登錄並訪問。但是ftp工具的21埠無法連上遠程主機,文件無法上傳。 問題出在Linux虛擬雲主機上面 ...
  • 現象:lostack啟動正常,logstack收集輸入redis數據,輸出到elasticsearch寫入失敗 提示:去建索引 的時候elasticsearch返回404 [2019-11-12T11:37:29,009][WARN ][logstash.outputs.elasticsearch] ...
  • 1、重啟系統,在出現選擇內核界面的時候按“e”鍵 2、移動游標到紅色找到LANG=zh_CN.UTF-8 增加“init=/sysroot/bin/sh” 修改後如下圖 3、使用"ctrl+x"來重啟伺服器系統,重啟後會進入到單用戶模式 1 增加如下配置修改root密碼 2 3 #mount -o ...
  • 故事背景:我司是做新零售的,機器支持4G、wifi、網線,可能會涉及到網路的切換和連接 項目需求:用戶在web端輸入wifi名稱和密碼,客戶端可以通過服務端下發的信息進行連接 技術調研:之前提到過nmcli指令,這次他又來了 a) 連接nmcli device wifi connect wifina ...
  • Linux下安裝zip解壓功能 Linux伺服器上一般預設沒是沒有有安裝zip命令 安裝zip指令 apt-get install zip 或 yum install zip 輸入zip OK linux安裝unzip命令:apt-get install unzip 或 yum install un ...
  • 1. configuer configure 是一個shell腳本,用來檢測安裝平臺是否符合要求,並通過配置參數生成makefile文件 2. make (make all 的簡寫) 編譯命令,從makefile文件中讀取命令,產生目標文件和可執行文件 3. make clean 清除編譯產生的可執 ...
  • ⽹絡時間服務和chrony 實驗練習: 1. 準備實驗環境: 2. 時間同步(centos6) 3. ntp軟體實現時間同步(centos6) centos6上預設安裝了ntp軟體包(包括客戶端和伺服器端),但是ntp同步需要⼀定時間才能完全同步時間的,⽽chrony同步時間⽐ntp快。centos ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...