Linux文件实时同步,可实现一对多
说明:该功能服务端安装sersync2,客户端安装rsync,原理就是服务端主动推送设定目录下的所有更新的文件到各个客户端rsync接收。
rsync大家都知道,是Linux自带的数据同步工具,而sersync2是google大神的开源项目http://code.google.com/p/sersync/
下面给出具体的实现步骤,实现的详细原理大家可以去上面的开源网址,上面说的很详细
- 客户端配置,首先系统安装rsync工具,
[root@yo57 ~]# vi /etc/rsyncd.conf uid=www
gid=www
max connections=36000
use chroot=no
log file=/var/log/rsyncd.log
pid file=/var/run/rsyncd.pid
lock file=/var/run/rsyncd.lock [yowebtongbu]
path=/Data/code/adserver
comment = yo web files
ignore errors = yes
read only = no
hosts allow = 192.168.0.0/24
hosts deny = *
[root@yo57 ~]# /usr/bin/rsync --daemon --config=/etc/rsyncd.conf
[root@yo57 ~]# ps -ef|grep rsyn
root 1070 29923 0 17:04 pts/4 00:00:00 grep rsyn
root 32069 1 0 16:54 ? 00:00:00 /usr/bin/rsync --daemon --config=/etc/rsyncd.conf - 写入开机启动项
[root@yo57 ~]# vi /etc/rc.local #!/bin/sh
#
# This script will be executed *after* all the other init scripts.
# You can put your own initialization stuff in here if you don't
# want to do the full Sys V style init stuff. touch /var/lock/subsys/local ulimit -SHn 51200
/usr/local/nagios/bin/nrpe -c /usr/local/nagios/etc/nrpe.cfg -d
/usr/local/nginx/sbin/nginx
/etc/init.d/php_fpm start
/usr/bin/rsync --daemon --config=/etc/rsyncd.conf - 服务器端
[root@10
local
]
# tar -zxvf sersync2.5.4_64bit_binary_stable_final.tar.gz
[root@10
local
]
# cd sersync2.5.4_64
[root@10 sersync2.5.4_64]
# ls
confxml.xml sersync2
[root@10 sersync2.5.4_64]
# vi confxml.xml
修改这一段即可
<localpath
watch
=
"/Data/code/adserver"
>
<remote ip=
"192.168.0.27"
name=
"yowebtongbu"
/>
<!--<remote ip=
"192.168.8.39"
name=
"tongbu"
/>-->
<!--<remote ip=
"192.168.8.40"
name=
"tongbu"
/>-->
<
/localpath
>
进行一次完整同步
[root@10 sersync2.5.4_64]
# ./sersync2 -r
写入脚本并放入开机启动项
[root@10 sersync2.5.4_64]
# cat /usr/local/sbin/sersync.sh
#!/bin/bash
PATH=
/bin
:
/sbin
:
/usr/bin
:
/usr/sbin
:
/usr/local/bin
:
/usr/local/sbin
:~
/bin
export
PATH
SDATH=
"/usr/local/sersync2.5.4_64"
SSTART=
"./sersync2 -r -d"
SPID=`
ps
-ef|
grep
'sersync2'
|
grep
-
v
'grep'
|
awk
'{print $2}'
`
function_start()
{
echo
-en
"\033[32;49;1mStarting sersync2......\n"
echo
-en
"\033[39;49;0m"
if
[ -t ${SPID} ];
then
cd
${SDATH}
${SSTART} >
/dev/null
2>&1
printf
"Serync2 is the successful start!\n"
else
printf
"Sersync2 is runing!\n"
exit
1
fi
}
function_stop()
{
echo
-en
"\033[32;49;1mStoping sersync2......\n"
echo
-en
"\033[39;49;0m"
if
[ -t ${SPID} ];
then
printf
"Sersync2 program is not runing!\n"
else
kill
${SPID}
printf
"Sersync2 program is stoped\n"
fi
}
function_restart()
{
echo
-en
"\033[32;49;1mRestart sersync2......\n"
echo
-en
"\033[39;49;0m"
if
[ -t ${SPID} ];
then
cd
${SDATH}
${SSTART} >
/dev/null
2>&1
else
kill
${SPID}
sleep
1
cd
${SDATH}
${SSTART} >
/dev/null
2>&1
fi
printf
"Sersync2 is the successful restart!\n"
}
function_kill()
{
killall sersync2
}
function_status()
{
if
!
ps
-ef|
grep
'sersync2'
|
grep
-
v
'grep'
>
/dev/null
2>&1
then
printf
"Sersync2 is down!!!\n"
else
printf
"Sersync2 is running now!\n"
fi
}
if
[
"$1"
=
"start"
];
then
function_start
elif
[
"$1"
=
"stop"
];
then
function_stop
elif
[
"$1"
=
"restart"
];
then
function_restart
elif
[
"$1"
=
"kill"
];
then
function_kill
elif
[
"$1"
=
"status"
];
then
function_status
else
echo
-en
"\033[32;49;1m Usage: sersync2 {start|stop|restart|kill|status}\n"
echo
-en
"\033[39;49;0m"
fi
[root@10 sersync2.5.4_64]
# vi /etc/rc.local
#!/bin/sh
#
# This script will be executed *after* all the other init scripts.
# You can put your own initialization stuff in here if you don't
# want to do the full Sys V style init stuff.
touch
/var/lock/subsys/local
#/etc/init.d/lemp start
/usr/local/nginx/sbin/nginx
/etc/init
.d
/php_fpm
start
/usr/local/zabbix/sbin/zabbix_agentd
/usr/local/sbin/sersync
.sh start
整个实现就这么简单,以后主服务器上面/Data/code/adserver目录下有新建、删除、修改文件或文件夹(包括下层递归)的的数据会自动推送到下面的各个服务端对应目录下,如果临时不需要该功能,kill掉服务端即可,操作完以后在手动开启服务端(此时客户端不用动)
Linux文件实时同步,可实现一对多的更多相关文章
- linux文件实时同步
参考博客:https://www.cnblogs.com/MacoLee/p/5633650.html 一.文件同步很简单 服务端:被动的接收传输过来的数据 客户端:主动提供数据给服务端 安装思路:服 ...
- linux下两台服务器文件实时同步方案设计和实现
inux下两台服务器文件实时同步方案设计和实现 假设有如下需求: 假设两个服务器: 192.168.0.1 源服务器 有目录 /opt/test/ 192.168.0.2 目标服务器 有目录 /o ...
- Linux服务器间文件实时同步的实现
使用场景 现有服务器A和服务器B,如果服务器A的指定目录(例如 /home/paul/rsync/ )中的内容发生变更(增删改和属性变更),实时将这些变更同步到服务器B的目标目录中(例如 /home/ ...
- (转)Linux下通过rsync与inotify(异步文件系统事件监控机制)实现文件实时同步
Linux下通过rsync与inotify(异步文件系统事件监控机制)实现文件实时同步原文:http://www.summerspacestation.com/linux%E4%B8%8B%E9%80 ...
- rsync+inotify 实现服务器之间目录文件实时同步(转)
软件简介: 1.rsync 与传统的 cp. tar 备份方式相比,rsync 具有安全性高.备份迅速.支持增量备份等优点,通过 rsync 可 以解决对实时性要求不高的数据备份需求,例如定期的备份文 ...
- rsync+inotify-tools文件实时同步
rsync+inotify-tools文件实时同步案例 全量备份 Linux下Rsync+sersync实现数据实时同步完成. 增量备份 纯粹的使用rsync做单向同步时,rsync的守护进程是运行在 ...
- inotify用法简介及结合rsync实现主机间的文件实时同步
一.inotify简介 inotify是Linux内核2.6.13 (June 18, 2005)版本新增的一个子系统(API),它提供了一种监控文件系统(基于inode的)事件的机制,可以监控文件系 ...
- eclipse 远程文件实时同步,eclipse远程部署插件
[转自] http://zhwj184.iteye.com/blog/1842730 eclipse 远程文件实时同步,eclipse远程部署插件 github地址:https://github.co ...
- Centos 6.5 rsync+inotify 两台服务器文件实时同步
rsync和inotify是什么我这里就不在介绍了,有专门的文章介绍这两个工具. 1.两台服务器IP地址分别为: 源服务器:192.168.1.2 目标服务器:192.168.1.3 @todo:从源 ...
随机推荐
- Scala入门3(特质线性化)
尝试设计一套特质,灵活的改动整数队列.队列有两种操作:put把整数放入队列,get从尾部取出它们.队列是先进先出的,get应该依照入队列的顺序取数据.提示:可以用mutable.ArrayBuffer ...
- linux安装及配置c++的opencv库
linux安装及配置c++的opencv库 前言: 最近想搞个机器视觉的比赛,要求是linux+opencv环境,没有做过opencv开发的我配置环境就配了两天,看来很多乱七八糟的博客,终于装好了.网 ...
- 深度学习基础系列(七)| Batch Normalization
Batch Normalization(批量标准化,简称BN)是近些年来深度学习优化中一个重要的手段.BN能带来如下优点: 加速训练过程: 可以使用较大的学习率: 允许在深层网络中使用sigmoid这 ...
- JAVAEE——SSH项目实战04:联系人添加、列表显示和修改
作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7159337.html 一.联系人添加 1.添加页面设计 linkman/list. ...
- 【java】Hibernate saveOrUpdate失效以及补救方案
有个需求是如果unique key不存在则插入,存在则更新. 简单的方式先select一下再insert 或者update,但是嫌太麻烦而且慢,所以采用Hibernate中session.saveOr ...
- BZOJ 2726: [SDOI2012]任务安排 [斜率优化DP 二分 提前计算代价]
2726: [SDOI2012]任务安排 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 868 Solved: 236[Submit][Status ...
- Gunicorn配置部分的翻译
写在前面,虽然翻译得很烂,但也是我的劳动成果,转载请注明出处,谢谢. Gunicorn版本号19.7.1 Gunicorn配置 概述 三种配置方式 优先级如下,越后的优先级越大 1.框架的设置(现在只 ...
- GIT(6)----fork和clone的区别,fetch与pull的区别
参考资料: [1].Git学习笔记:fork和clone的区别,fetch与pull的区别 [2].在Github和Git上fork之简单指南
- A* search算法解迷宫
这是一个使用A* search算法解迷宫的问题,细节请看:http://www.laurentluce.com/posts/solving-mazes-using-python-simple-recu ...
- LAMP LNMP 和 LNMPA
LAMP指的是:Linux+Apache+MySQL+Perl/PHP/Python LAMP是一个缩写,它指一组通常一起使用来运行动态网站或者服务器的自由软件: Linux,操作系统: Apache ...