最近在搞阿里云的SLB,但是阿里云没有提供WEB服务器的文件同步,还好rsync可以实现,但弄了好久,所以希望阿里云能够早日出想新浪SAE的自动同步功能,或者出一个针对ESC的rsync配置视频或文档也好啊,让我们这些小白少走些弯路。好了,废话少说,我们来学习一下rsync的配置。
目的是想从rsync服务端(10.171.88.115)的文件同步到rsync客户端(10.172.222.246),这里的ip地址是ECS的内网地址
一、首先安装rsync,怎样安装都行,rpm,yum,还是你用源码安装都可以。因为我用的是阿里云的ESC,yum install rsync就ok了。
二、配置rsync服务
1.先建立个同步数据的帐号1
2
3groupadd rsync
useradd -g rsync -s /sbin/nologin -d /home/rsync rsync
passwd rsync
2.rsyncd.conf1
vim /etc/rsyncd.conf
1 | secrets file = /etc/rsyncd.secrets |
(注:以上注释部分真实使用时请去掉,不去掉会有语法错误,下同!!!)
3.rsyncd.secrets1
vi /etc/rsyncd.secrets
rsyncd.secrets是存储rsync服务的用户名和密码的,它是一个明文的文本文件,下面给出一个rsyncd.secrets文件的例子:
1 | rsync:abcde |
因为rsyncd.secrets存储了rsync服务的用户名和密码,所以非常重要,因此文件的属性必须设为600,只有所有者可以读写:1
chmod 600 /etc/rsyncd.secrets
4.rsyncd.motd1
vi /etc/rsyncd.motd
rsyncd.motd记录了rsync服务的欢迎信息,你可以在其中输入任何文本信息,如:1
Welcome to use the rsync services!
5.services1
vi /etc/services
services并不是rsync的配置文件,这一步也可以不做。而修改了services文件的好处就在于系统知道873端口对就的服务名为rsync。修改services的方法就是确保services中有如下两行,没有的话就自行加入:1
2rsync 873/tcp # rsync
rsync 873/udp # rsync
6./etc/xinetd.d/rsync1
vi /etc/xinetd.d/rsync
建立一个名为/etc/xinetd.d/rsync文件,输入以下内容:1
2
3
4
5
6
7
8
9
10service rsync
{
disable = no
socket_type = stream
wait = no
user = root
server = /usr/local/rsync/bin/rsync #写你rsync的运行文件目录
server_args = - -daemon
log_on_failure += USERID
}
保存后,就可以运行rsync服务了。
7.如果有防火墙 rsync服务器和防火墙,关掉对rsync的屏蔽1
iptables -A INPUT -p tcp -m state --state NEW -m tcp - -dport 873 -j ACCEPT
8.运行rsync 输入以下命令: (可能xinetd 没安装 yum安装一下就行)1
/etc/rc.d/init.d/xinetd reload
这样rsync服务就在这台机器上(10.171.88.115)运行起来了,接下来就是如何来使用它了。 如果想开机自启动1
vi /etc/rc.d/rc.local
将/etc/rc.d/init.d/xinetd reload或者service xinetd start加进去就可以了
三、rsync客户端配置
1.安装rsync,无需启动rsync服务,因为它又不当rsync服务器
2.1
rsync -avz --progress --delete rsync@10.171.88.115::www /alidata/www
有设置权限(服务端目录设置时有authusers:xxxxx)的需要输入密码,如果没有就立即同步啦 如果嫌每次输入密码麻烦,新建一个密码文件,#touch /etc/rsync.secret 编辑1
vim /etc/rsync.secret
1 | abcde #里面写密码就行了 |
再1
chmod 600 /etc/rsync.secret
然后同步时命令就可以这样写:1
rsync -avz --progress --delete --password-file=/etc/rsync.secret rsync@10.171.88.115::www /alidata/www
3.crontb实现自动同步 先新建一个sh文件1
2touch /root/rsync.sh
vim /root/rsync.sh
里面输入:1
2!/bin/bash
rsync -avz --progress --delete --password-file=/etc/rsync.secret rsync@10.171.88.115::www /alidata/www >> /root/rsync-crontablog.txt
(这里把输出的结果写到了一个txt文件里)
ok!下面写crontb文件:1
2crontb -e
*/1 7-23 * * * /root/rsync.sh
让它7点到晚上23点每隔一分钟同步 修改文件权限:1
chmod 755 /root/rsync.sh
大功告成!!!
(注:以上是客户端向服务端取文件,你也可以从客户端向SERVER端上传文件,那就要反过来,1个服务器做客户端,n台服务器做server端,也就是要配很多次server端的配置,有兴趣的同学可以尝试一下。另外我这里用的是crontab进行最快一分钟一次有点延时的实时同步,大家可以尝试rsync+inotify进行真正的实时同步,推荐博客:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=11840697&id=3890795)