歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux基礎 >> 關於Linux

Rsync同步的記錄

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/

Copyright © Linux教程網 All Rights Reserved