Rsync:
官方網站:http://rsync.samba.org/
官方文檔:http://rsync.samba.org/documentation.html
品茶:文章還沒寫完,暫時可能入不了你的法眼。請跳過。
注:
1、有關密碼的權限設置必須是600
一、簡介:
rsync是類unix系統下的數據鏡像備份工具,從軟件的命名上就可以看出來了——remote sync。它的特性如下:
可以鏡像保存整個目錄樹和文件系統。
可以很容易做到保持原來文件的權限、時間、軟硬鏈接等等。
無須特殊權限即可安裝。
優化的流程,文件傳輸效率高。
可以使用rcp、ssh等方式來傳輸文件,當然也可以通過直接的socket連接。
支持匿名傳輸,以方便進行網站鏡象。
二、簡單序過程:
1、Rsync服務端啟動
2、載入配置文件
3、客戶端連接,服務端驗證配置文件,權限等,然後交互文件。
三、安裝過程:
1、安裝Rsync xinetd(托管rsync)
#yum -y install rsync xinetd
2、xinetd讓其啟動時啟動
#vi /etc/xinetd.d/rsync
[ disable = no ]
3、防火牆策略
#vi /etc/sysconfig/iptables
[ -A RH-Firewall-1-INPUT -p tcp -m tcp --dport 873 -j ACCEPT ]
#service iptables restart
4、編輯配置文件
#vi /etc/rsyncd.conf
[
max connections = 5
log file = /var/log/rsync.log
uid = nobody
gid = nobody
[web]
path = /web/html
read only = yes
hosts allow = 192.168.2.0/24
]
5、設置開機啟動
#service xinetd start
#chkconfig xinetd --level 3 on
#netstat -ant
::873
6、SeLinux設置
#setenforce Permissive
#vim /etc/sysconfig/selinux
[ SELINUX=disabled ]
7、客戶端測試
#rsync --progress -av --delete rsync://192.168.2.88/web /web/backup/html/
正式環境(權限自配)
具體配置選項請參照rsync手冊:#rsync --help
#vim /etc/rsyncd.conf
[
max connections = 5
log file = /var/log/rsync.log
log pid = /var/log/rsync.pid
uid = nobody(可用文件屬主)
gid = nobody(可用文件屬組)
use chroot = no
[www]
path = /web/www
read only = true
list = false
hosts allow = 192.168.2.0/24
hosts deny = 0.0.0.0/32
auth users = www
secrets file = /etc/rsync.pass
[bbs]
path = /web/bbs
read only = true
list = false
hosts allow = 192.168.2.0/24
hosts deny = 0.0.0.0/32
auth users = bbs
secrets file = /etc/rsync.pass
[blog]
path = /web/blog
read only = true
list = false
hosts allow = 192.168.2.0/24
hosts deny = 0.0.0.0/32
auth users = blog
secrets file = /etc/rsync.pass
]
#vim /etc/rsync.pass
[
www:111111
bbs:222222
blog:333333
]
#chmod 600 /etc/rsync.pass
rsync的命令格式:
rsync [OPTION]... SRC [SRC]... [USER@]HOST:DEST
rsync [OPTION]... [USER@]HOST:SRC DEST
rsync [OPTION]... SRC [SRC]... DEST
rsync [OPTION]... [USER@]HOST::SRC [DEST]
rsync [OPTION]... SRC [SRC]... [USER@]HOST::DEST
rsync [OPTION]... rsync://[USER@]HOST[:PORT]/SRC [DEST]
rsync有六種不同的工作模式:
拷貝本地文件;當SRC和DES路徑信息都不包含有單個冒號":"分隔符時就啟動這種工作模式。
使用一個遠程shell程序(如rsh、ssh)來實現將本地機器的內容拷貝到遠程機器。當DST路徑地址包含單個冒號":"分隔符時啟動該模式。
本欄目更多精彩內容:http://www.bianceng.cn/OS/Linux/
使用一個遠程shell程序(如rsh、ssh)來實現將遠程機器的內容拷貝到本地機器。當SRC地址路徑包含單個冒號":"分隔符時啟動該模式。
從遠程rsync服務器中拷貝文件到本地機。當SRC路徑信息包含"::"分隔符時啟動該模式。
從本地機器拷貝文件到遠程rsync服務器中。當DST路徑信息包含"::"分隔符時啟動該模式。
列遠程機的文件列表。這類似於rsync傳輸,不過只要在命令中省略掉本地機信息即可。
-v, --verbose 詳細模式輸出
-q, --quiet 精簡輸出模式
-c, --checksum 打開校驗開關,強制對文件傳輸進行校驗
-a, --archive 歸檔模式,表示以遞歸方式傳輸文件,並保持所有文件屬性,等於-rlptgoD
-r, --recursive 對子目錄以遞歸模式處理
-R, --relative 使用相對路徑信息
-b, --backup 創建備份,也就是對於目的已經存在有同樣的文件名時,將老的文件重新命名為~filename。可以使用--suffix選項來指定不同的備份文件前綴。
--backup-dir 將備份文件(如~filename)存放在在目錄下。
-suffix=SUFFIX 定義備份文件前綴
-u, --update 僅僅進行更新,也就是跳過所有已經存在於DST,並且文件時間晚於要備份的文件。(不覆蓋更新的文件)
-l, --links 保留軟鏈結
-L, --copy-links 想對待常規文件一樣處理軟鏈結
--copy-unsafe-links 僅僅拷貝指向SRC路徑目錄樹以外的鏈結
--safe-links 忽略指向SRC路徑目錄樹以外的鏈結
-H, --hard-links 保留硬鏈結
-p, --perms 保持文件權限
-o, --owner 保持文件屬主信息
-g, --group 保持文件屬組信息
-D, --devices 保持設備文件信息
-t, --times 保持文件時間信息
-S, --sparse 對稀疏文件進行特殊處理以節省DST的空間
-n, --dry-run現實哪些文件將被傳輸
-W, --whole-file 拷貝文件,不進行增量檢測
-x, --one-file-system 不要跨越文件系統邊界
-B, --block-size=SIZE 檢驗算法使用的塊尺寸,默認是700字節
-e, --rsh=COMMAND 指定替代rsh的shell程序
--rsync-path=PATH 指定遠程服務器上的rsync命令所在路徑信息
-C, --cvs-exclude 使用和CVS一樣的方法自動忽略文件,用來排除那些不希望傳輸的文件
--existing 僅僅更新那些已經存在於DST的文件,而不備份那些新創建的文件
--delete 刪除那些DST中SRC沒有的文件
--delete-excluded 同樣刪除接收端那些被該選項指定排除的文件
--delete-after 傳輸結束以後再刪除
--ignore-errors 及時出現IO錯誤也進行刪除
--max-delete=NUM 最多刪除NUM個文件
--partial 保留那些因故沒有完全傳輸的文件,以是加快隨後的再次傳輸
--force 強制刪除目錄,即使不為空
--numeric-ids 不將數字的用戶和組ID匹配為用戶名和組名
--timeout=TIME IP超時時間,單位為秒
-I, --ignore-times 不跳過那些有同樣的時間和長度的文件
--size-only 當決定是否要備份文件時,僅僅察看文件大小而不考慮文件時間
--modify-window=NUM 決定文件是否時間相同時使用的時間戳窗口,默認為0
-T --temp-dir=DIR 在DIR中創建臨時文件
--compare-dest=DIR 同樣比較DIR中的文件來決定是否需要備份
-P 等同於 --partial
--progress 顯示備份過程
-z, --compress 對備份的文件在傳輸時進行壓縮處理
--exclude=PATTERN 指定排除不需要傳輸的文件模式
--include=PATTERN 指定不排除而需要傳輸的文件模式
--exclude-from=FILE 排除FILE中指定模式的文件
--include-from=FILE 不排除FILE指定模式匹配的文件
--version 打印版本信息
--address 綁定到特定的地址
--config=FILE 指定其他的配置文件,不使用默認的rsyncd.conf文件
--port=PORT 指定其他的rsync服務端口
--blocking-io 對遠程shell使用阻塞IO
-stats 給出某些文件的傳輸狀態
--progress 在傳輸時現實傳輸過程
--log-format=FORMAT 指定日志文件格式
--password-file=FILE 從FILE中得到密碼
--bwlimit=KBPS 限制I/O帶寬,KBytes per second
-h, --help 顯示幫助信息
客戶端連接:
#vim /etc/rsync.www
[ 111111 ]
#vim /etc/rsync.bbs
[ 222222 ]
#vim /etc/rsync.blog
[ 333333 ]
設置密碼文件權限:
#chmod 600 /etc/rsync.{www,bbs,blog}
客戶端連接www模塊:
#rsync --progress -av --delete [email protected]::www /web/backup/www/ --passwordfile=/etc/rsync.www
客戶端連接bbs模塊:
#rsync --progress -av --delete [email protected]::bbs /web/backup/bbs/ --password-file=/etc/rsync.bbs
客戶端連接blog模塊:
#rsync --progress -av --delete [email protected]::blog /web/backup/blog/ --password-file=/etc/rsync.blog
客戶端推送:
rsync --progress -avr --delete /web/www/html/ [email protected]::www --password-file=/etc/rsync.www
注意:/web/www/html/ html後面有/表示同步此目錄下所有的文檔。而不是同步html文件夾。
任務計劃:
#crontab -e
[
*/1 * * * * rsync --progress -av --delete [email protected]::www /data/backup/www/ --password-file=/etc/rsync.www
]
如果你要搭建網絡源,或本地源同步,來同步最新的文件。我在官網找到一個好源,具體源地址。國內的好像都不支持Rsync。
源列表:http://www.centos.org/modules/tinycontent/index.php?id=30
#rsync --progress -av --delete linux.mirrors.es.net::centos /data/CentOS/
品茶:安全方面,請參照默認安全以即最小權限來設置。
轉:http://netkiller.github.com/linux/storage/inotify-tools.html
inotify-tools + rsync
-m 是保持一直監聽
-r 是遞歸查看目錄
-q 是打印出事件~
-e create,move,delete,modify 監聽 創建 移動 刪除 寫入 事件
inotifywait -mrq --event create,delete,modify,move --format '%w %e' /your_path | while read w e; do
if [ "$e" = "IGNORED" ]; then
continue
fi
rsync -az --delete $w username@your_ip:$w
done
#!/bin/sh
# A slightly complex but actually useful example
inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %f' \
-e close_write /home/billy | while read date time file; do
rsync /home/billy/${file} rsync://[email protected]/backup/${file} && \
echo "At ${time} on ${date}, file ${file} was backed up via rsync"
done
[root@development ~]# cat inotify-rsync
#!/bin/bash
# $Id: chapter.storage.inotify.xml 334 2012-02-01 05:59:34Z netkiller $ #
# Author neo<[email protected]> #
# monitor path
monitor_path=cms
#inotifywait path
INOTIFYWAIT=inotifywait
# rsync image file
function images {
local file=$1
rsync -az --delete $file /tmp/images/$file
# rsync ${file} ${rsync_url}/${file}
}
# rsync html file
function html {
local file=$1
rsync -az --delete $file /tmp/$file
}
$INOTIFYWAIT -mrq --event close_write --format '%w%f %e' $monitor_path | while read file event; do
if [ "$event" = "CLOSE_WRITE,CLOSE" ]; then
ext=$(echo $file | awk -F'.' '{print $2}')
if [ $ext = 'jpg' ]; then
images $file
fi
if [ $ext = 'html' ]; then
html $file
fi
fi
done &
本欄目更多精彩內容:http://www.bianceng.cn/OS/Linux/