刚刚看到一个老牌的ECVPS跑路了,在这里再说一下再可靠的服务商也要做好留一手的准备,谁还没可能有个小灾小难,做好备份,多处备份,你手里有备份才是王道。作为站长或者运维,在服务器上从这台同步到另外一台是很频繁的操作,之前我们介绍过用scp传输文件或目录,但是不能判断文件是否更改,是否有文件增删,每次都是覆盖,会浪费掉很多时间。今天推荐的是另外一个利器rsync,全称remote synchronize。它的特性如下:安装方便、可以镜像保存整个目录树和文件系统、可以容易的保持原来文件的权限、时间、软硬链接等等、文件传输效率高、可以使用ssh等方式来传输文件也可以通过直接的socket连接等。
安装rsync
CentOS/Fedora/RHEL:
1 |
yum install rsync |
Debian/Ubuntu:
1 |
apt-get install rsync |
rsync使用教程
rsync有两种工作方式:SSH和daemon。
- SSH方式是使用系统上的用户通过SSH进行同步操作。
- daemon方式是rsync服务器会开一个873端口,等待客户端去连接,连接是进行验证,通过后进行同步。
一、SSH模式下进行同步操作
1 |
rsync -options SRC DEST |
SRC代表源目录,DEST代表目标目录,当通过ssh链接时, 有时需要指定ssh端口, 请使用这个方式:rsync -options -e “ssh -p 10000” SRC DEST
下面举例说明一下常用到的场景:
1.1:本地拷贝目录,将/home/wwwroot/xxx/拷贝到/data/wwwroot/xxx/
rsync -avu /home/wwwroot/xxx/ /data/wwwroot/xxx/
1.2:将本地目录拷贝到远程服务器
1 |
rsync -avu --progress --delete /home/wwwroot/xxx.net/ root@1.2.3.4:/home/wwwroot/xxx.net/ |
如果改了SSH端口,需要加-e “ssh -p 你的SSH端口”,如果不想显示具体传输过程可以去掉P参数,如果需要压缩传输可以加z参数。
–delete 参数,这样当本地删除的文件,远程端也会删除,保持完整的一致。
1.3:将远程服务器目录拷贝到本地
1 |
rsync -avu --progress --delete root@1.2.3.4:/home/wwwroot/xxx.net/ /home/wwwroot/xxx.net/ |
二、daemon模式的配置
rsync daemon模式是以rsync服务器形式运行,首先我们需要创建rsync服务器的配置文件,配置文件:/etc/rsyncd.conf 默认此文件可能不存在,需要自己创建,配置信息如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
port = 873 uid = root gid = root use chroot = no //使用chroot到文件系统中的目录中 max connections = 100 //最大并发连接数 #motd file = /etc/rsyncd.motd //定义服务器信息的,自己写 rsyncd.motd 文件内容 pid file = /var/run/rsyncd.pid lock file = /var/run/rsyncd.lock log file = /var/log/rsyncd.log timeout = 300 [xxx] //自定义模块 path = /home/wwwroot/xxx.net/ //用来指定要备份的目录 ignore errors //可以忽略一些IO错误 read only = no //设置no,客户端可以上传文件,yes是只读 write only = no //no为客户端可以下载,yes 不能下载 hosts allow = 192.168.2.0/24 //允许连接的IP,强烈建议加上你允许的IP,多个IP逗号隔开 list = yes //客户请求时,使用模块列表 auth users = xxx //连接用户名,是虚拟用户与linux系统用户无关,多个用户名逗号隔开 secrets file = /etc/rsyncd.secrets //验证密码文件,文件格式为:用户名:密码 |
写入配置时请将上面的注释信息去掉,并调整里面的相关参数。我们也提供了一个模板文件rsyncd.conf可自己下载放到/etc/下并修改相关参数。
/etc/rsyncd.secrets 文件权限必须是600,创建好该文件后可以执行:
1 |
chmod 600 /etc/rsyncd.secrets |
注意:默认rsync服务器并不是自动启动的!
Debian/Ubuntu上是带自启动脚本的,修改 /etc/default/rsync ,将里面的RSYNC_ENABLE=false 改成 RSYNC_ENABLE=true 保存就设成开机自启动了。
CentOS上启动脚本都是不带的,执行:
1 2 3 |
wget http://soft.xxx.net/sync/rsync/init.d.rsync -O /etc/init.d/rsync && chmod +x /etc/init.d/rsync && chkconfig rsync on 如果不报错的话就会开机自启动了。 完成上面设置后,执行: |
1 |
/etc/init.d/rsync start |
即可启动。
测试rsync服务器:
1 |
rsync -avuP xxx@192.227.165.35::xxx/home/wwwroot/xxx.net/ |
进行连接测试,注:@前的xxx为自定义模块里设置的用户名,::后面的xxx为你自定义模块的名称。
rsync使用小技巧:
1、可以用rsync快速删除大量文件:
建立一个空的文件夹:
1 |
mkdir /root/blank |
用rsync删除目标目录:
1 |
rsync --delete-before -a -H -v --progress --stats /root/blank/ /home/wwwroot/cache/ |
这样我们要删除的 cache目录就会被清空了,删除的速 度会非常快。
2、如果开启了iptables防火墙,请将873端口加入防火墙允许规则。
1 2 |
iptables -I INPUT -p tcp --dport 873 -j ACCEPT iptables -I OUTPUT -p tcp --sport 873 -j ACCEPT |
3、用户可以自己根据自己的需求选择SSH或daemon模式
配合crontab定时执行任务 自动完成同步、备份等工作。
rsync 常用参数的具体解释如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
-v, --verbose 详细模式输出 -q, --quiet 精简输出模式 -c, --checksum 打开校验开关,强制对文件传输进行校验 -a, --archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD -r, --recursive 对子目录以递归模式处理 -b, --backup 创建备份,也就是对于目的已经存在有同样的文件名时,将老的文件重新命名为~filename。可以使用--suffix选项来指定不同的备份文件前缀。 -suffix=SUFFIX 定义备份文件前缀 -u, --update 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件。(不覆盖更新的文件) -l, --links 保留软链结 -p, --perms 保持文件权限 -o, --owner 保持文件属主信息 -g, --group 保持文件属组信息 -t, --times 保持文件时间信息 -e, --rsh=COMMAND 指定使用rsh、ssh方式进行数据同步 --delete 删除那些DST中SRC没有的文件 --delete-excluded 同样删除接收端那些被该选项指定排除的文件 --delete-after 传输结束以后再删除 --ignore-errors 及时出现IO错误也进行删除 --force 强制删除目录,即使不为空 --timeout=TIME IP超时时间,单位为秒 --progress 显示备份过程 -z, --compress 对备份的文件在传输时进行压缩处理 --exclude=PATTERN 指定排除不需要传输的文件模式 --include=PATTERN 指定不排除而需要传输的文件模式 --exclude-from=FILE 排除FILE中指定模式的文件 --include-from=FILE 不排除FILE指定模式匹配的文件 |
发表评论
要发表评论,您必须先登录。