遠程實時增量備份 rsync


 
備份方式
  1. cp 本機復制
  2. scp 遠程復制
    1. 推  (本地上傳到遠程服務器)
      • 格式
        • scp 1.txt root@ip:[路徑]
        • [root@m01 ~]# scp 1.txt root@172.16.1.41:/opt/
    2. 拉  (遠程服務器文件下載到本地)
      • 格式
        • scp root@ip:[路徑] ./
        • [root@m01 ~]# scp root@172.16.1.41:/opt/2.txt
  3. rsync 遠程復制/備份
    • 支持 增量復制
 
------
rsync
------
 
概要
 
1 介紹
2 特性
3 應用場景(備份方式)
4 傳輸方式
5 傳輸模式
6 參數
7 rsync守護進程模式(目的:實現實時備份)
---服務端
---客戶端
---實時同步
 
 
詳細
 
 
 
1 介紹
 
rsync英文稱為remote synchronizetion,從軟件的名稱就可以看出來,rsync具有可使本地和遠程兩台主機之間的數據快速復制同步鏡像、遠程備份的功能,這個功能類似於ssh帶的scp命令,但是又優於scp命令的功能,scp每次都是全量拷貝,而rsync可以增量拷貝。當然,rsync還可以在本地主機的不同分區或目錄之間全量及增量的復制數據,這又類似cp命令。但是同樣也優於cp命令,cp每次都是全量拷貝,而rsync可以增量拷貝。
 
rsync官方地址: https://rsync.samba.org/
rsync監聽端口:873
rsync運行模式:C/S   client/server
 
 
rsync簡稱叫做遠程同步,可以實現不同主機之間的數據同步,方式全量和增量
 
2 特性
 
支持拷貝特殊文件,如連接文件、設備等
可以有排除指定文件或目錄同步的功能,相當於打包命令tar的排除功能
可以做到保持原文件或目錄的權限、時間、軟硬鏈接、屬主、組等所有屬性均不改變 –p
可以實現增量同步,既只同步發生變化的數據,因此數據傳輸效率很高(tar-N)
可以使用rcp、rsh、ssh等方式來配合傳輸文件(rsync本身不對數據加密)
可以通過socket(進程方式)傳輸文件和數據(服務端和客戶端)*****
支持匿名的活認證(無需系統用戶)的進程模式傳輸,可以實現方便安全的進行數據備份和鏡像
 
 
3 應用場景(備份方式)
 
  • 全量備份
    • 每次都是從頭開始復制
  • 增量備份
    • 接續上次復制
 
4 傳輸方式
 
  1. push
    • 數據從本地(客戶端)推送至服務端
  2. pull
    • 數據從服務端拉取到本地(客戶端)
 
5 傳輸模式
 
  1. 本地方式(類似cp)
  2. 遠程方式
    • 類似於scp,又不同於scp, scp只支持全量備份,rsync支持增量備份和差異備份
  3. 守護進程方式(客戶端和服務端)
    • 借助inotify這個軟件來實現實時同步
 
6 rsync參數使用
 
上傳文件
 
格式:
sync -azvP 本地文件路徑 root@遠程PC的IP 冒號 遠程PC文件路徑
 
下載文件
 
格式:
sync -azvP  root@遠程PC的IP 冒號 遠程PC文件路徑 本地文件路徑
 
詳細
  • -a           #歸檔模式傳輸, 等於-tropgDl    -t -r -o -p -g -D -l
  • -v           #詳細模式輸出, 打印速率, 文件數量等
  • -P           #顯示同步的過程及傳輸時的進度等信息
  • -z           #傳輸時進行壓縮以提高效率
  • 其他(1)
  • -r           #遞歸傳輸目錄及子目錄,即目錄下得所有目錄都同樣傳輸
  • -t           #保持文件時間信息
  • -o           #保持文件屬主信息
  • -g           #保持文件屬組信息
  • -p           #保持文件權限
  • -l           #保留軟連接
  • -D           #保持設備文件信息
  • -L           #保留軟連接指向的目標文件
  • -e           #使用的信道協議,指定替代rsh的shell程序(很少用)
  • 其他
  • --append            # 指定文件接着上次傳輸中斷處繼續傳輸
    • [root@m01 ~]# rsync -azvP --append 2.txt root@172.16.1.41:/root/test
  • --append-verify     # 使用參數續傳(在斷點續傳之后,驗證一下文件:  如果文件有修改,從頭開始傳; 沒有,從斷點處傳輸)
  • --exclude=PATTERN   # 指定排除不需要傳輸的文件
    • [root@m01 ~]# rsync -avzP --append-verify --exclude=2.txt  ./* root@172.16.1.41:/opt/
  • --exclude-from=file # 按照文件指定內容排除
    • [root@m01 ~]# rsync -avzP --append-verify --exclude-from=/tmp/exclude.txt  ./* root@172.16.1.41:/opt/
  • --bwlimit=100       # 限速傳輸(單位:MB)
    • [root@m01 ~]# rsync -avzP --append-verify --bwlimit=10  ./* root@172.16.1.41:/opt/
  • --delete            # 讓目標目錄和源目錄數據保持一致
  • --password-file=xxx # 使用密碼文件
  • --port              # 指定端口傳輸
 
 
7 rsync守護進程模式
  • 目的:實現實時備份
 
step1---服務端
 
1-1 # 安裝rsync軟件
[root@backup ~]# yum install -y rsync
 
1-2 # 修改配置文件
 
[root@backup opt]# vim /etc/rsyncd.conf
    注意:編輯完再進去檢查下,[backup]后邊行確認無注釋的#
uid = rsync
gid = rsync
port = 873
fake super = yes
use chroot = no
max connections = 200
timeout = 600
ignore errors
read only = false
list = false
auth users = rsync_backup
secrets file = /etc/rsync.passwd
log file = /var/log/rsyncd.log
#####################################
[backup]
comment = welcome to backup!
path =/backup
[linux]
comment = welcome to linux!
path=/tmp/linux
 
 
 
配置詳解
 
1-3 # 創建系統用戶(目的:啟動rsync軟件需要一個用戶; 另啟動該軟件隨操作系統)
[root@backup opt]# groupadd rsync -g 666
[root@backup opt]# useradd rsync -u 666 -g 666 -M -s /sbin/nologin -r
    -M 指定創建系統用戶; /nologin 不需要登陸
 
1-4 # 創建密碼文件
[root@backup opt]# echo "rsync_backup:123456" > /etc/rsync.passwd
    格式:
    echo "虛擬用戶名(配置文件里):新設定密碼" 密碼路徑(配置文件里)
 
1-5 # "密碼文件"授權(必須授權為600)
[root@backup opt]# chmod 600 /etc/rsync.passwd
 
1-6 # 創建備份目錄
[root@backup opt]# mkdir /backup
[root@backup opt]# mkdir /tmp/linux
    
1-7 # 目錄授權
[root@backup opt]# chown rsync.rsync /backup/
[root@backup opt]# chown rsync.rsync /tmp/linux/
    創建的目錄---默認屬主數組是root,啟動的應用程序是rsync,這些目錄沒有權限,所以需要授權
 
1-8 # 關閉防火牆和selinux
[root@backup opt]# systemctl disable --now firewalld
[root@backup opt]# setenforce 0
 
1-9 # 啟動rsyncd服務
[root@backup opt]# systemctl start rsyncd
 
 
 
演示
 
 
補充:
  • 開機自啟動
    • 格式
      • systemctl enable --now 軟件名
 
 
step2 ---在客戶端測試
  • 在客戶端上傳資料到"服務端rsync"
  • 方式: 3中
 
方法一:自己輸入密碼
 
[root@m01 ~]# rsync -avzP ./* rsync_backup@172.16.1.41::backup
  • rsync_backup : 虛擬用戶,只在數據傳輸時使用
  • 172.16.1.41  : backup服務端的IP
  • backup       : 模塊名稱(注意語句中前邊是兩個冒號)
 
 
 
 
方法二:設置密碼文件,運行時讀取(常用此方式)
 
  1. 編寫密碼文件
    • [root@backup opt]# echo "123456" > /etc/rsync.passwd
    • 密碼"1233456"就是 服務端rsync軟件的的配置文件中設定的密碼,要一致
  2. 授權"密碼文件"
    • [root@m01 ~]# chmod 600 /etc/rsync.passwd
  3. 上傳備份
    • [root@m01 ~]# rsync -avzP --password-file=/etc/rsync.passwd  ./* rsync_backup@172.16.1.41::linux
 
方法三:添加環境變量(很少用)
 
  1. 定義環境變量
    • export RSYNC_PASSWORD=123456
  2. 上傳備份
    • [root@m01 ~]# rsync -avzP  ./* rsync_backup@172.16.1.41::linux
 
 
step3---實時同步
 
rsync是不支持實時同步的,通常我們借助於inotify這個軟件來實時監控文件變化,一旦inotify監控到文件變,則立即調用rsync進行同步
 
 
1、安裝inotify(裝在客戶端)
# yum -y install inotify-tools
 
2、實時同步(在客戶端輸入命令語句)
  • 用到"實時監控軟件"及語句
  • 注意以下備份語句中密碼輸入方式為"將密碼寫入文件"(step2的方式2)
 
[root@m01 ~]# /usr/bin/inotifywait  -mrq  --format '%Xe  %w  %f' -e create,modify,delete,attrib,close_write  /root | while read line;do
    cd  /root
    rsync -avzP --delete --password-file=/etc/rsync.passwd ./* rsync_backup@172.16.1.41::backup
done
    
 
 
 
inotify參數介紹
  • -m 持續監控
  • -r 遞歸
  • -q 靜默,僅打印時間信息
  • --timefmt 指定輸出時間格式
  • --format 指定事件輸出格式
    • %Xe 事件
    • %w 目錄
    • %f 文件
  • -e 指定監控的事件
    • access 訪問
    • modify 內容修改
    • attrib 屬性修改
    • close_write 修改真實文件內容
    • open 打開
    • create 創建
    • delete 刪除
    • umount 卸載
    
>>>監控語句---實時監控(在客戶端)
[root@m01 ~]# /usr/bin/inotifywait  -mrq  --format '%Xe  %w  %f' -e create,modify,delete,attrib,close_write  /root
 
 
 
---補充:
 
創建固定大小文件
 
  • dd if=/dev/zero of=3.txt bs=100M count=10
 
修改 屬主屬組
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM