備份就是這麼簡單:教你輕鬆使用 Linux rsync 指令
在現代電腦日常使用中,資料備份顯得格外重要。而對於 Linux 使用者來說,rsync 指令是備份和同步檔案的常用方法。它可以在不同系統之間或本機資料夾之間實現快速且有效率的資料同步。
方案背景:A伺服器與B伺服器之間(可1對1,也可多對多,在此以簡單的1對1舉例)需要資料同步,此方案常用於遠端災備。

同步方案根據應用程式場景大約有兩種,定時同步和即時同步。定時同步具有同步時間固定、即時性差、消耗資源較小的特性;即時同步具有即時性強、同步密集、較耗資源等特性。
一、定時同步
#1、安裝軟體:
yum install rsync -y
2、免機密登入(也可使用明文採用模擬互動式登入方式,但從安全角度出發還是建議使用免密登入):
ssh-keygen -t rsa
產生後可以進入目錄cd ~/.ssh/ 把產生的金鑰~/.ssh/id_rsa.pub內容複製到遠端主機的/root/.ssh/authorized_keys中
在這裡很多同學對以上的操作為什麼就不用輸入密碼的問題感到好奇,了解免密登入的同學可以跳過這段介紹。這裡介紹下免密登入的原理:
rsa又稱非對稱金鑰演算法,對應的是對稱金鑰演算法。
所謂對稱金鑰演算法就是A和B通信,為了雙方能確認對方的身份,A和B約定一個雙方都知道的金鑰k來決定身份如下:
A => (mk) B A發送m明文和K密鑰跟B,B確認K密鑰和之前A約定的一樣,就能確定A的身份是真實的。反之B到A的通信也是如此。
非對稱加密需要兩個金鑰:公鑰 (publickey) 和私鑰 (privatekey)。公鑰和私鑰是一對,如果用公鑰對資料加密,那麼只能用對應的私鑰解密。如果用私鑰對資料加密,只能用對應的公鑰進行解密。因為加密和解密用的是不同的金鑰,所以稱為非對稱加密。
所以以上的操作把A伺服器的公鑰共享跟了B伺服器(遠端主機),所以A伺服器登入B伺服器就不再需要傳統的互動式輸入密碼登錄,B伺服器能透過A伺服器的公鑰而確認A伺服器的真實性(私鑰)。
[root@localhost ~]# cd ~/.ssh/ [root@localhost .ssh]# ls id_rsa id_rsa.pub known_hosts
3、寫shell腳本
[root@localhost ~]# vim back.sh #!/bin/sh rsync -avz -e 'ssh -p 22' root@x.x.x.x:/XXX/pub /data/
注意:rsync的資料同步分為拉和推兩種不同的動作,在編寫腳本之前,一定要測試指令是否能正常執行。
4、crontab定時執行設定(每天3點執行腳本)
到此,定時同步就配置好了。
二、即時同步

#Inotify簡介
Inotify 是一個 Linux特性,從版本2.6.13開始提供,它監控檔案系統操作,例如讀取、寫入和創建。 Inotify 反應靈敏,用法非常簡單,並且比 cron 任務的繁忙輪詢高效得多。
開始設定Inotify
附註:在開始之前需要在伺服器A和B上都安裝好rsync。
1、在伺服器B上調整inotify核心參數,vim /etc/sysctl.conf
#fs.inotify.max_queued_events = 16384 fs.inotify.max_user_instances = 1024 fs.inotify.max_user_watches = 1048576
2、讓調整inotify核心參數立刻生效
#
sysctl -p3、安裝Inotify-Tool工具
# 先安装扩展包源,否则inotify-tools找不到 yum install epel-release yum install inotify-tools4、開啟兩個終端,一個終端執行創建刪除等操作,另一個執行Inotify-Tool工具,測試Inotify-Tool工具時候正常
inotifywait -mrq -e modify,create,move,delete /var/www/ inotifywait:用于持续监控,实时输出结果 inotifywatch:用于短期监控,任务完成后再出结果5、寫腳本
vim /root/tongbu.sh
#!/bin/bash INOTIFY_CMD="inotifywait -mrq -e modify,create,attrib,move,delete /root/cs" RSYNC_CMD="rsync -avz -e 'ssh - p 22' /root/cs/ root@x.x.x.x:/root/cs/ " $INOTIFY_CMD | while read DIRECTORY EVENT FILE do if [ $(pgrep rsync | wc -l) -le 0 ] ; then $RSYNC_CMD fi done註:這裡要特別注意,邏輯關係不要搞混了,是B伺服器推送跟A伺服器。 ### ###6、新增開機自動後台自動執行,編輯/etc/profile文件,在最後一行加入下面語句###
/bin/bash /root/tongbu.sh &###到此定時同步和即時同步都講解完畢。根據不同的場景應用不同的方案,需要靈活應對,特別要注意一點的是。即時同步的方案,監控目錄千萬不能設定成日誌目錄,不然伺服器cpu飆漲很有可能會當機。 ### ###總之,rsync 指令是一個非常強大、靈活且有效率的檔案同步和備份工具。無論是在日常使用或是生產環境中,都能夠發揮出其獨特的優勢。透過本文的介紹和實踐,相信大家已經掌握了這個指令的基本用法和技巧。希望大家在未來的 Linux 使用中,能夠更好地利用 rsync 指令來管理和保護自己的資料! ###
以上是備份就是這麼簡單:教你輕鬆使用 Linux rsync 指令的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Linux和Windows的安全模型各有優勢。 Linux提供靈活性和可定制性,通過用戶權限、文件系統權限和SELinux/AppArmor實現安全。 Windows則注重用戶友好性,依賴WindowsDefender、UAC、防火牆和BitLocker保障安全。

Linux和Windows在硬件兼容性上不同:Windows有廣泛的驅動程序支持,Linux依賴社區和廠商。解決Linux兼容性問題可通過手動編譯驅動,如克隆RTL8188EU驅動倉庫、編譯和安裝;Windows用戶需管理驅動程序以優化性能。

Linux和Windows在虛擬化支持上的主要區別在於:1)Linux提供KVM和Xen,性能和靈活性突出,適合高定制環境;2)Windows通過Hyper-V支持虛擬化,界面友好,與Microsoft生態系統緊密集成,適合依賴Microsoft軟件的企業。

Linux系統管理員的主要任務包括系統監控與性能調優、用戶管理、軟件包管理、安全管理與備份、故障排查與解決、性能優化與最佳實踐。 1.使用top、htop等工具監控系統性能,並進行調優。 2.通過useradd等命令管理用戶賬戶和權限。 3.利用apt、yum管理軟件包,確保系統更新和安全。 4.配置防火牆、監控日誌、進行數據備份以確保系統安全。 5.通過日誌分析和工具使用進行故障排查和解決。 6.優化內核參數和應用配置,遵循最佳實踐提升系統性能和穩定性。

學習Linux並不難。 1.Linux是一個開源操作系統,基於Unix,廣泛應用於服務器、嵌入式系統和個人電腦。 2.理解文件系統和權限管理是關鍵,文件系統是層次化的,權限包括讀、寫和執行。 3.包管理系統如apt和dnf使得軟件管理方便。 4.進程管理通過ps和top命令實現。 5.從基本命令如mkdir、cd、touch和nano開始學習,再嘗試高級用法如shell腳本和文本處理。 6.常見錯誤如權限問題可以通過sudo和chmod解決。 7.性能優化建議包括使用htop監控資源、清理不必要文件和使用sy

Linux管理員的平均年薪在美國為75,000至95,000美元,歐洲為40,000至60,000歐元。提升薪資可以通過:1.持續學習新技術,如雲計算和容器技術;2.積累項目經驗並建立Portfolio;3.建立職業網絡,拓展人脈。

Linux的主要用途包括:1.服務器操作系統,2.嵌入式系統,3.桌面操作系統,4.開發和測試環境。 Linux在這些領域表現出色,提供了穩定性、安全性和高效的開發工具。

互聯網運行不依賴單一操作系統,但Linux在其中扮演重要角色。 Linux廣泛應用於服務器和網絡設備,因其穩定性、安全性和可擴展性受歡迎。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Dreamweaver CS6
視覺化網頁開發工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能