一、rsync服务端的快速配置:
1.修改xinetd文件,开启rsync服务:
#sed -i 's/disable.*/disable = no/' /etc/xinetd.d/rsync
2.建立rsync的配置文件:
#touch /etc/rsyncd.conf
#cat >> /etc/rsyncd.conf << EOF
strict modes= true
port= 873
logfile= /var/log/rsyncd.log
pidfile= /var/run/rsyncd.pid
lock file= /var/log/rsyncd.log
max connections= 50
uid= root
gid= root
use chroot =no
read only = no
hosts allow = 192.168.2.0/24,192.168.1.51 #允许访问的IP范围,多个网段可以用","隔开。
hosts deny = *
#transfer logging =yes
#[modules]
[bakdata] #服务端需要备份数据的模块名,可以建立多个用于对应不同的目录。
path= /data/mysql/ #服务端数据存放目录,要根据实际情况修改。
auth users= bakuser #用于访问rsync服务的用户名,可以随意定义,但要与/etc/rsyncd.scrt对应。
ignore errors
secrets file= /etc/rsyncd.scrt #rsync服务的认证文件。
EOF
3.建立rsync服务的认证文件,且修改其权限:
#echo "bakuser:gc895316" > /etc/rsyncd.scrt
#chown root.root /etc/rsyncd.scrt
#chmod 600 /etc/rsyncd.scrt
4.将rsync加入系统服务,并使其随系统开机启动:
#chkconfig rsync on
#/usr/bin/rsync --daemon
#echo "/usr/local/rsync --daemon" >> /etc/rc.local
二、客户端配置(不使用rsyncd.conf文件中定义的模块同步可以直接跳过此步):
#echo "gc895316" > /etc/rsync.password
#chown root.root /etc/rsync.password
#chmod 600 /etc/rsync.password
三、rsync的使用:
1.通过在服务端rsyncd.conf文件中定义的模块同步数据:
在客户端通过下拉的方式,将服务端数据下载到本地的/home/mysql目录下:
rsync -vzrtopg --progress --password-file=/etc/rsync.psaaword bakuser@192.168.2.161::bakdata /home/mysql
在客户端通过上传的方式,将本地的/home/mysql目录下数据同步到服务器的/data/mysql目录下:
rsync -vzrtopg --progress --password-file=/etc/rsync.psaaword /home/mysql bakuser@192.168.2.161::bakdata
注:这里也可以不使用--password-file参数,手工输入密码。
2.同步服务端rsyncd.conf文件中定义的模块下的部分数据:
在客户端通过下拉的方式,将服务端/home/mysql/gcbuy下载到本地的/home/mysql/gcbuy目录下:
rsync -vzrtopg --progress --password-file=/etc/rsync.psaaword bakuser@192.168.2.161::bakdata/gcbuy /home/mysql/gcbuy/
在客户端通过上传的方式,将本地的/home/mysql/gcbuy目录下数据同步到服务器的/data/mysql/gcbuy目录下:
rsync -vzrtopg --progress --password-file=/etc/rsync.psaaword /home/mysql/gcbuy bakuser@192.168.2.161::bakdata/gcbuy
注:这里也可以不使用--password-file参数,手工输入密码。
3.不使用rsyncd.conf文件中定义的模块,对指定目录同步:
在客户端通过下拉的方式,将服务端/home/mysql/gongchang文件夹下载到本地的/home/mysql目录下:
rsync -vzrtopg --progress bakuser@192.168.2.161:/home/mysql/gongchang /home/mysql #需要注意的是,bakuser必须是系统用户,这类似于scp。
在客户端通过上传的方式,将本地的/home/mysql/test目录下数据同步到服务器的/data/mysql/目录下:
rsync -vzrtopg --progress /home/mysql/test bakuser@192.168.2.161:/data/mysql #需要注意的是,bakuser必须是系统用户,这类似于scp。
四、rsync的实用实例:
1.在本地机器上对两个目录进行同步
rsync -zvr /db/ /www/
参数:
-z 开启压缩
-v 详情输出
-r 表示递归
2.利用 rsync -a 让同步时保留时间标记
rsync 选项 -a 称为归档模式,执行以下操作
递归模式
保留符号链接
保留权限
保留时间标记
保留用户名及组名
rsync -azv /www/ /home/chow/
3.仅同步一个文件
rsync -v /db/YUM_Install.doc /home/chow/
4.同步时指定远程 shell
用 -e 参数可以指定远程 ssh ,比如用 rsync -e ssh 来指定为 ssh
rsync -azv -e ssh chow@192.168.2.161:/home/chow/test/ /root/test_dir/ #chow是192.168.2.161上的一个普通的系统用户,而后提示输入密码,需要输入chow的系统密码。
注:通过普通用户同步192.168.2.161上的文件时,chow对该文件得有读取权限。
5.不要覆盖被修改过的目的文件
使用 rsync -u 选项可以排除被修改过的目的文件
rsync -azvu chow@192.168.2.161:/home/chow/test/ /root/test_dir/ #chow是2.161上的一个普通系统用户。
6.仅仅同步目录权(不同步文件)
使用 -d 参数
rsync -d -v chow@192.168.2.161:/home/chow/test/ /root/test_dir/ #chow是2.161上的一个普通系统用户。
7.删除在目的文件夹中创建的文件
用 --delete 参数
rsync -zav --delete chow@192.168.2.161:/home/chow/test/ /root/test/
8.不要在目的文件夹中创建新文件
有时能只想同步目的地中存在的文件,而排除源文件中新建的文件,可以使用 – -exiting 参数
rsync -azv --existing chow@192.168.2.161:/home/chow/test/ /root/test/
9.查看源和目的文件之间的改变情况
用 -i 参数
rsync -avzi chow@192.168.2.161:/home/chow/test/ /root/test/
输出结果中在每个文件最前面会多显示 9 个字母,分别表示为
> 已经传输
f 表示这是一个文件
d 表示这是一个目录
s 表示尺寸被更改
t 时间标记有变化
o 用户被更改
g 用户组被更改
10.在传输时启用包含和排除模式(类似正则)
rsync -azv --include 'VM*' --exclude 'vm*' chow@192.168.2.161:/home/chow/test/ /root/test/
11.不要传输大文件
使用 -- max-size 参数
rsync -azv --max-size='2M' chow@192.168.2.161:/home/chow/test/ /root/test/ #大于2M的文件不被同步的。
12.传输所有文件
不管有没有改变,再次把所有文件都传输一遍,用 -W 参数
rsync -azvW chow@192.168.2.161:/home/chow/test/ /root/test/ /root/test/
1.修改xinetd文件,开启rsync服务:
#sed -i 's/disable.*/disable = no/' /etc/xinetd.d/rsync
2.建立rsync的配置文件:
#touch /etc/rsyncd.conf
#cat >> /etc/rsyncd.conf << EOF
strict modes= true
port= 873
logfile= /var/log/rsyncd.log
pidfile= /var/run/rsyncd.pid
lock file= /var/log/rsyncd.log
max connections= 50
uid= root
gid= root
use chroot =no
read only = no
hosts allow = 192.168.2.0/24,192.168.1.51 #允许访问的IP范围,多个网段可以用","隔开。
hosts deny = *
#transfer logging =yes
#[modules]
[bakdata] #服务端需要备份数据的模块名,可以建立多个用于对应不同的目录。
path= /data/mysql/ #服务端数据存放目录,要根据实际情况修改。
auth users= bakuser #用于访问rsync服务的用户名,可以随意定义,但要与/etc/rsyncd.scrt对应。
ignore errors
secrets file= /etc/rsyncd.scrt #rsync服务的认证文件。
EOF
3.建立rsync服务的认证文件,且修改其权限:
#echo "bakuser:gc895316" > /etc/rsyncd.scrt
#chown root.root /etc/rsyncd.scrt
#chmod 600 /etc/rsyncd.scrt
4.将rsync加入系统服务,并使其随系统开机启动:
#chkconfig rsync on
#/usr/bin/rsync --daemon
#echo "/usr/local/rsync --daemon" >> /etc/rc.local
二、客户端配置(不使用rsyncd.conf文件中定义的模块同步可以直接跳过此步):
#echo "gc895316" > /etc/rsync.password
#chown root.root /etc/rsync.password
#chmod 600 /etc/rsync.password
三、rsync的使用:
1.通过在服务端rsyncd.conf文件中定义的模块同步数据:
在客户端通过下拉的方式,将服务端数据下载到本地的/home/mysql目录下:
rsync -vzrtopg --progress --password-file=/etc/rsync.psaaword bakuser@192.168.2.161::bakdata /home/mysql
在客户端通过上传的方式,将本地的/home/mysql目录下数据同步到服务器的/data/mysql目录下:
rsync -vzrtopg --progress --password-file=/etc/rsync.psaaword /home/mysql bakuser@192.168.2.161::bakdata
注:这里也可以不使用--password-file参数,手工输入密码。
2.同步服务端rsyncd.conf文件中定义的模块下的部分数据:
在客户端通过下拉的方式,将服务端/home/mysql/gcbuy下载到本地的/home/mysql/gcbuy目录下:
rsync -vzrtopg --progress --password-file=/etc/rsync.psaaword bakuser@192.168.2.161::bakdata/gcbuy /home/mysql/gcbuy/
在客户端通过上传的方式,将本地的/home/mysql/gcbuy目录下数据同步到服务器的/data/mysql/gcbuy目录下:
rsync -vzrtopg --progress --password-file=/etc/rsync.psaaword /home/mysql/gcbuy bakuser@192.168.2.161::bakdata/gcbuy
注:这里也可以不使用--password-file参数,手工输入密码。
3.不使用rsyncd.conf文件中定义的模块,对指定目录同步:
在客户端通过下拉的方式,将服务端/home/mysql/gongchang文件夹下载到本地的/home/mysql目录下:
rsync -vzrtopg --progress bakuser@192.168.2.161:/home/mysql/gongchang /home/mysql #需要注意的是,bakuser必须是系统用户,这类似于scp。
在客户端通过上传的方式,将本地的/home/mysql/test目录下数据同步到服务器的/data/mysql/目录下:
rsync -vzrtopg --progress /home/mysql/test bakuser@192.168.2.161:/data/mysql #需要注意的是,bakuser必须是系统用户,这类似于scp。
四、rsync的实用实例:
1.在本地机器上对两个目录进行同步
rsync -zvr /db/ /www/
参数:
-z 开启压缩
-v 详情输出
-r 表示递归
2.利用 rsync -a 让同步时保留时间标记
rsync 选项 -a 称为归档模式,执行以下操作
递归模式
保留符号链接
保留权限
保留时间标记
保留用户名及组名
rsync -azv /www/ /home/chow/
3.仅同步一个文件
rsync -v /db/YUM_Install.doc /home/chow/
4.同步时指定远程 shell
用 -e 参数可以指定远程 ssh ,比如用 rsync -e ssh 来指定为 ssh
rsync -azv -e ssh chow@192.168.2.161:/home/chow/test/ /root/test_dir/ #chow是192.168.2.161上的一个普通的系统用户,而后提示输入密码,需要输入chow的系统密码。
注:通过普通用户同步192.168.2.161上的文件时,chow对该文件得有读取权限。
5.不要覆盖被修改过的目的文件
使用 rsync -u 选项可以排除被修改过的目的文件
rsync -azvu chow@192.168.2.161:/home/chow/test/ /root/test_dir/ #chow是2.161上的一个普通系统用户。
6.仅仅同步目录权(不同步文件)
使用 -d 参数
rsync -d -v chow@192.168.2.161:/home/chow/test/ /root/test_dir/ #chow是2.161上的一个普通系统用户。
7.删除在目的文件夹中创建的文件
用 --delete 参数
rsync -zav --delete chow@192.168.2.161:/home/chow/test/ /root/test/
8.不要在目的文件夹中创建新文件
有时能只想同步目的地中存在的文件,而排除源文件中新建的文件,可以使用 – -exiting 参数
rsync -azv --existing chow@192.168.2.161:/home/chow/test/ /root/test/
9.查看源和目的文件之间的改变情况
用 -i 参数
rsync -avzi chow@192.168.2.161:/home/chow/test/ /root/test/
输出结果中在每个文件最前面会多显示 9 个字母,分别表示为
> 已经传输
f 表示这是一个文件
d 表示这是一个目录
s 表示尺寸被更改
t 时间标记有变化
o 用户被更改
g 用户组被更改
10.在传输时启用包含和排除模式(类似正则)
rsync -azv --include 'VM*' --exclude 'vm*' chow@192.168.2.161:/home/chow/test/ /root/test/
11.不要传输大文件
使用 -- max-size 参数
rsync -azv --max-size='2M' chow@192.168.2.161:/home/chow/test/ /root/test/ #大于2M的文件不被同步的。
12.传输所有文件
不管有没有改变,再次把所有文件都传输一遍,用 -W 参数
rsync -azvW chow@192.168.2.161:/home/chow/test/ /root/test/ /root/test/