Lysncd即Live Syncing Daemon,它是開源的數(shù)據(jù)實時同步工具(后臺進程),基于inotify和rsync。
lsyncd會密切監(jiān)測本地服務(wù)器上的參照目錄,當發(fā)現(xiàn)目錄下有文件或目錄變更后,立刻通知遠程服務(wù)器,并通過rsync 或rsync+ssh方式實現(xiàn)文件同步。這樣做的好處就是,你可以利用Lsyncd搭建一個VPS同步鏡像,應(yīng)用場景例如CDN鏡像、網(wǎng)站數(shù)據(jù)備份、網(wǎng)站搬家等等。
一、Lsyncd安裝方法
Lsyncd官網(wǎng)是:http://axkibe.github.io/lsyncd/,Linux安裝命令如下:
# Ubuntu sudo apt install lsyncd # CentOS sudo yum install epel-release sudo yum install lsyncd # 編譯安裝 cmake . make sudo make install
安裝成功后,你可以在:/usr/share/doc/lsyncd/examples,看到Lsyncd配置使用示例,你可以參考這些示例自己再編寫配置。
二、Lsyncd配置說明
打開Lsyncd的配置,你可以看到主要包括兩個部分:一是設(shè)置,另一個是同步 。settings里面是全局設(shè)置,–開頭表示注釋,代碼如下:
settings { logfile = "/var/log/lsyncd/lsyncd.log", statusFile = "/var/log/lsyncd/lsyncd.status" } sync { default.rsyncssh, source = "/root/linsir", --源目錄 host = "192.168.2.16", --目的主機 targetdir = "/root/remote", --遠程目錄 delete = true, delay = 0, exclude={ ".txt" --排除 }, rsync = { binary = "/usr/bin/rsync", archive = true, --歸檔 compress = true, --壓縮 verbose = true, owner = true, --屬主 perms = true, --權(quán)限 _extra = {"--bwlimit=2000"}, }, ssh = { port = 3322 } }
下面是幾個常用選項說明:
logfile 定義日志文件
stausFile 定義狀態(tài)文件
nodaemon=true 表示不啟用守護模式,默認
statusInterval 將lsyncd的狀態(tài)寫入上面的statusFile的間隔,默認10秒
inotifyMode 指定inotify監(jiān)控的事件,默認是CloseWrite,還可以是Modify或CloseWrite or Modify
maxProcesses 同步進程的最大個數(shù)。假如同時有20個文件需要同步,而maxProcesses = 8,則最大能看到有8個rysnc進程
maxDelays 累計到多少所監(jiān)控的事件激活一次同步,即使后面的delay延遲時間還未到
sync 里面是定義同步參數(shù),可以繼續(xù)使用maxDelays來重寫settings的全局變量。一般第一個參數(shù)指定lsyncd以什么模式運行:rsync、rsyncssh、direct三種模式:
default.rsync :本地目錄間同步,使用rsync,也可以達到使用ssh形式的遠程rsync效果,或daemon方式連接遠程rsyncd進程;
default.direct :本地目錄間同步,使用cp、rm等命令完成差異文件備份;
default.rsyncssh :同步到遠程主機目錄,rsync的ssh模式,需要使用key來認證
source 同步的源目錄,使用絕對路徑。target 定義目的地址.對應(yīng)不同的模式有幾種寫法:
/tmp/dest :本地目錄同步,可用于direct和rsync模式
172.29.88.223:/tmp/dest :同步到遠程服務(wù)器目錄,可用于rsync和rsyncssh模式,拼接的命令類似于/usr/bin/rsync -ltsd –delete –include-from=- –exclude=* SOURCE TARGET,剩下的就是rsync的內(nèi)容了,比如指定username,免密碼同步
172.29.88.223::module :同步到遠程服務(wù)器目錄,用于rsync模式
其它優(yōu)化選項有:
init 這是一個優(yōu)化選項,當init = false,只同步進程啟動以后發(fā)生改動事件的文件,原有的目錄即使有差異也不會同步。默認是true
delay 累計事件,等待rsync同步延時時間,默認15秒(最大累計到1000個不可合并的事件)。也就是15s內(nèi)監(jiān)控目錄下發(fā)生的改動,會累積到一次rsync同步,避免過于頻繁的同步。(可合并的意思是,15s內(nèi)兩次修改了同一文件,最后只同步最新的文件)
delete 為了保持target與souce完全同步,Lsyncd默認會delete = true來允許同步刪除。它除了false,還有startup、running值,請參考 Lsyncd 2.1.x ‖ Layer 4 Config ‖ Default Behavior。
excludeFrom 排除選項,后面指定排除的列表文件,如excludeFrom = “/etc/lsyncd.exclude”,如果是簡單的排除,可以使用exclude = LIST。這里的排除規(guī)則寫法與原生rsync有點不同,更為簡單:
監(jiān)控路徑里的任何部分匹配到一個文本,都會被排除,例如/bin/foo/bar可以匹配規(guī)則foo
如果規(guī)則以斜線/開頭,則從頭開始要匹配全部
如果規(guī)則以/結(jié)尾,則要匹配監(jiān)控路徑的末尾
?匹配任何字符,但不包括/
*匹配0或多個字符,但不包括/
**匹配0或多個字符,可以是/
rsync配置選項有:
bwlimit 限速,單位kb/s,與rsync相同(這么重要的選項在文檔里竟然沒有標出)
compress 壓縮傳輸默認為true。在帶寬與cpu負載之間權(quán)衡,本地目錄同步可以考慮把它設(shè)為false
perms 默認保留文件權(quán)限。
其它還有rsyncssh模式獨有的配置項,如host、targetdir、rsync_path、password_file,見后文示例。rsyncOps={“-avz”,”–delete”}這樣的寫法在2.1.*版本已經(jīng)不支持。
lsyncd.conf可以有多個sync,各自的source,各自的target,各自的模式,互不影響。
三、Lsyncd本地同步
首先,創(chuàng)建日志文件,用于跟蹤。
mkdir /var/log/lsyncd touch /var/log/lsyncd/lsyncd.{log,status}
然后,創(chuàng)建配置文件。
mkdir /etc/lsyncd vim /etc/lsyncd/lsyncd.conf.lua
配置文件寫入以下內(nèi)容(注意把Source和Target分別替換你的源目錄路徑和目標目錄路徑):
settings = { logfile = "/var/log/lsyncd/lsyncd.log", statusFile = "/var/log/lsyncd/lsyncd.status" } sync { default.rsync, source = "/var/www/source_dir", target = "/home/snail/backup", }
最后,啟動lsyncd服務(wù):systemctl restart lsyncd,往源目錄中添加文件,看看目標目錄中會不會同步增加。如果沒有,請查看日志。
四、Lsyncd遠程同步
用Lsyncd實現(xiàn)兩臺VPS主機服務(wù)器之間實時同步。首先,進入你的源VPS主機,使用S-S-H命令遠程登錄到目標VPS主機上。
ssh root@your_remote_server_IP #或者指定端口 ssh root@your_remote_server_IP -p 1234
接著,執(zhí)行命令,在目標VPS上生成密鑰:
ssh-keygen -t rsa # 全部回車默認
生成密鑰成功后,你需要將目標VPS上的密鑰文件復(fù)制到源VPS主機上,路徑保持一致。
然后,重新進入到源VPS上,執(zhí)行命令:ssh-copy-id root@your_remote_server_IP ,再次輸入遠程登錄密碼,確認添加密鑰。
密鑰添加成功后,現(xiàn)在你就可以在源VPS上直接使用:ssh root@your_remote_server_IP,不需要輸入密碼就可以進入到遠程VPS了。然后按照上面本地同步的方法,創(chuàng)建日志和配置文件,注意替換你自己的源目錄與目標目錄路徑。
settings = { insist = true, logfile = "/var/log/lsyncd/lsyncd.log", statusFile = "/var/log/lsyncd/lsyncd.status" } sync { default.rsyncssh, source = "/home/www", host = "115.28.65.xxx", targetdir = "/home/backup" }
如果你的目標VPS的端口不是默認的22,你可以用以下方法指定端口:
settings = { insist = true, logfile = "/var/log/lsyncd/lsyncd.log", statusFile = "/var/log/lsyncd/lsyncd.status" } sync { default.rsyncssh, source = "/home/www", host = "115.28.65.xxx", targetdir = "/home/backup" ssh = { port = 36000 } }
最后,重新啟動: systemctl restart lsyncd。
稍等一會兒,你就可以看到目標目錄已經(jīng)有了同步過來的文件了。
同時,打開日志文件,你也可以看到操作記錄。
Lsyncd其他模式示例(請根據(jù)實際替換路徑與IP地址):
settings { logfile ="/usr/local/lsyncd-2.1.5/var/lsyncd.log", statusFile ="/usr/local/lsyncd-2.1.5/var/lsyncd.status", inotifyMode = "CloseWrite", maxProcesses = 8, } -- 遠程目錄同步,rsync模式 + rsyncd daemon sync { default.rsync, source = "/tmp/src", target = "syncuser@172.29.88.xxx::module1", delete="running", exclude = { ".*", ".tmp" }, delay = 30, init = false, rsync = { binary = "/usr/bin/rsync", archive = true, compress = true, verbose = true, password_file = "/etc/rsyncd.d/rsync.pwd", _extra = {"--bwlimit=200"} } } -- 遠程目錄同步,rsync模式 + ssh shell sync { default.rsync, source = "/tmp/src", target = "172.29.88.xxx:/tmp/dest", -- target = "root@172.29.88.xxx:/remote/dest", -- 上面target,注意如果是普通用戶,必須擁有寫權(quán)限 maxDelays = 5, delay = 30, -- init = true, rsync = { binary = "/usr/bin/rsync", archive = true, compress = true, bwlimit = 2000 -- rsh = "/usr/bin/ssh -p 22 -o StrictHostKeyChecking=no" -- 如果要指定其它端口,請用上面的rsh } } -- 遠程目錄同步,rsync模式 + rsyncssh,效果與上面相同 sync { default.rsyncssh, source = "/tmp/src2", host = "172.29.88.xxx", targetdir = "/remote/dir", excludeFrom = "/etc/rsyncd.d/rsync_exclude.lst", -- maxDelays = 5, delay = 0, -- init = false, rsync = { binary = "/usr/bin/rsync", archive = true, compress = true, verbose = true, _extra = {"--bwlimit=2000"}, }, ssh = { port = 1234 } }
五、總結(jié)
Lsyncd配置起來還是蠻簡單的,大家嫌麻煩的話不需要研究他們的參數(shù),直接使用本篇文章中的Lsyncd遠程同步示例代碼,其它的選項保持默認的即可。Lsyncd同步的速度取決你的VPS主機的帶寬,并且是增量同步備份。
如何實現(xiàn)一對多的實時同步呢?解決的方法就是直接在配置中重復(fù)添加多個目標目錄路徑。
sync{ default.rsync, source='/sourcedir', target='targethost1:/targetdir' } sync{ default.rsync, source='/sourcedir', target='targethost2:/targetdir' } sync{ default.rsync, source='/sourcedir', target='targethost3:/targetdir' }
設(shè)置Lsyncd開機啟動。代碼如下:
/etc/init.d/lsyncd start chkconfig lsyncd on