文档章节

rsync实现多台linux服务器的文件同步

在下头真的很硬
 在下头真的很硬
发布于 06/19 21:26
字数 1100
阅读 65
收藏 0

一、首先安装rsync,怎样安装都行,rpm,yum,还是你用源码安装都可以。因为我用的是阿里云的ESC,yum install rsync就ok了。

二、配置rsync服务
1.先建立个同步数据的帐号

1
2
3
groupadd rsync
useradd -g rsync -s /sbin/nologin -d /home/rsync rsync
passwd rsync

 

2.rsyncd.conf

1
vim /etc/rsyncd.conf

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
secrets file = /etc/rsyncd.secrets
motd file = /etc/rsyncd.motd
read only = yes
list = yes
uid = rsync /*同步用的帐号,此账户对模块要有相应的权限*/
gid = rsync /*同步用的帐号组*/
hosts allow = 10.172.222.246 #哪些电脑可以访问rsync服务,多个ip用空格隔开
hosts deny = 192.168.100.0/24 #哪些电脑不可以访问rsync服务
max connections = 0 /*最大连接数,0表示无限制*/
log file = /var/log/rsyncd.log
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
#再定义rsync目录
[www]
comment = www 's directory from 10.171.88.115
path = /alidata/www /*模块的路径*/
chroot = false
authusers=rsync #不设置代表客户端同步无需密码</pre>

(注:以上注释部分真实使用时请去掉,不去掉会有语法错误,下同!!!)

3.rsyncd.secrets

1
vi /etc/rsyncd.secrets

 

rsyncd.secrets是存储rsync服务的用户名和密码的,它是一个明文的文本文件,下面给出一个rsyncd.secrets文件的例子:

1
rsync:abcde

因为rsyncd.secrets存储了rsync服务的用户名和密码,所以非常重要,因此文件的属性必须设为600,只有所有者可以读写:

1
chmod 600 /etc/rsyncd.secrets

 

4.rsyncd.motd

1
vi /etc/rsyncd.motd

 

rsyncd.motd记录了rsync服务的欢迎信息,你可以在其中输入任何文本信息,如:

1
Welcome to use the rsync services!

 

5.services

1
vi /etc/services

 

services并不是rsync的配置文件,这一步也可以不做。而修改了services文件的好处就在于系统知道873端口对就的服务名为rsync。修改services的方法就是确保services中有如下两行,没有的话就自行加入:

1
2
rsync  873/tcp  # rsync
rsync  873/udp  # rsync

 

6./etc/xinetd.d/rsync

1
vi /etc/xinetd.d/rsync

 

建立一个名为/etc/xinetd.d/rsync文件,输入以下内容:

1
2
3
4
5
6
7
8
9
10
service 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
2
touch /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
2
crontb -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?

© 著作权归作者所有

共有 人打赏支持
在下头真的很硬
粉丝 0
博文 20
码字总数 4426
作品 0
深圳
私信 提问
sersync+rsync实时同步配置案例

目前业内比较靠谱的同步解决方案有: rsync+inotify-tools,Openduckbill+inotify-tools和rsync+sersync 前两者由于是基于脚本语言编写,所以规范程度,执行效率相对rsync+sersync就稍微弱一...

feilong0663
07/03
0
0
rsync , rsync + ssh, rsync + lsyncd 多种同步方案与比较

利用 ssh+rsync 只需要在服务器端打开 ssh 服务, 并启动 xinetd 中 rsync 服务则可使用 a. 增量同步 rsync -av /src-dir/. user@ipadress:/dest-dir/. b. 镜像同步 rsync -av --delete /src-...

文弱书生_罗剑
2015/08/19
0
0
rsync+sersync实现服务器文件同步

集群间服务器实现数据的同步一直是一个问题,比如一个lvs集群中,如果有上百台RS服务器,当更新Web程序时,如何在这么多台服务器间进行快速的更新,这是一个问题,如果使用手动更新,或者scp...

彭锐
05/04
0
0
centos搭建rsync服务!

rsync是Unix下的一款应用软件,它能同步更新两处计算机的文件与目录,并适当利用差分编码以减少数据传输。rsync中一项与其他大部分类似程序或协定中所未见的重要特性是镜像对每个目标只需要一...

求学ing
2013/08/07
0
0
Rsync+Inotify-client 实现实时同步

在前面的博文实践记录之-Rsync镜像备份介绍了镜像备份工具Rsync的安装和使用.但在大数据时代,rsync的不足之处也暴露出来. 首先.rsync本身实现不了实时备份.靠系统的crontab实现的话也受...

乜波
2014/07/16
0
0

没有更多内容

加载失败,请刷新页面

加载更多

支付宝api实现转账到单个账号

项目后台需要实现用户提现功能,支付宝平台对应的就是“单笔转账到支付宝账户”。具体实现见代码,无套路! 肯定需要先申请支付宝商户账号相关信息。以下为个人沙箱环境实现代码,生产上只需...

貔貅叔
28分钟前
3
0
Spark自定义维护kafka的offset到zk

import kafka.common.TopicAndPartitionimport kafka.message.MessageAndMetadataimport kafka.serializer.StringDecoderimport kafka.utils.ZkUtilsimport org.I0Itec.zkclient.ZkC......

hblt-j
28分钟前
2
0
bash运行脚本的几种方式

bash shell 脚本执行的方法有多种,本文作一个总结,供大家学习参考。 假设我们编写好的shell脚本的文件名为hello.sh,文件位置在/data/shell目录中并已有执行权限。 方法一:切换到shell脚本...

吴伟祥
38分钟前
2
0
看图了解RocksDB

摘要: 它是一个高性能的Key-Value数据库。设计了完善的持久化机制,同时保证性能和安全性。能够良好的支持范围查询,因为K-V记录就是按照Key来排序的。 下图为写入的流程: 可以看到主要的三...

阿里云官方博客
47分钟前
1
0
关于Python pandas模块输出每行中间省略号问题

关于Python数据分析中pandas模块在输出的时候,每行的中间会有省略号出现,和行与行中间的省略号....问题,其他的站点(百度)中的大部分都是瞎写,根本就是复制黏贴以前的版本,你要想知道其...

上官夏洛特
48分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部