Rsync同步、Rsync+Lsync实时同步
Rsync同步、Rsync+Lsync实时同步
原创博文http://www.cnblogs.com/elvi/p/7658049.html
#!/bin/sh
#Myde by Elven @
#centos 6x , centos 7x
#Rsync同步、Rsync+Lsync实时同步 ### 全局配置
#Rsync服务端配置
RS_IP=192.168.20.1
BkDir=/www/backup
#Lsync目录配置
Source="/www/backup/tobak/"
Target="test@$RS_IP::test" ### rsync同步服务端(备份目标地址)
function rs_s() {
echo "#目录设置"
mkdir -p $BkDir/test
touch $BkDir/test/abc{..}.txt
# useradd rsync -s /sbin/nologin -M
# chown -R rsync /www/backup/web echo "#安装……"
[[ `rpm -qa rsync|wc -l` == ]] && { yum install rsync -y; } || echo rsync is OK
#yum install -y rsync
echo "#Rsync服务端配置"
echo "
# rsync配置
uid = root
gid = root
user chroot = no
max connections =
timeout =
port =
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsyncd.lock
log file = /var/log/rsyncd.log
hosts allow = 192.168.20.0/
hosts deny = *
secrets file = /etc/rsync.db
ignore errors [backup]
comment= backup server
path=/www/backup/
read only = false
list = true
auth users = rsync [test]
comment= backup test
path=/www/backup/test/
read only = false
list = true
auth users = test ">/etc/rsyncd.conf
#用户验证
echo "rsync:rsync2017">/etc/rsync.db
echo "test:test2017">>/etc/rsync.db
chown root:root /etc/rsync.db
chmod /etc/rsync.db
chmod /etc/rsyncd.conf [[ `uname -r` == *el6* ]] && {
# centos6用xinetd管理rsync进程
#rsync --daemon --address=192.168.20.41
[[ `rpm -qa xinetd|wc -l` == ]] && { yum install xinetd -y; } || echo xinetd is OK
sed -in '6s#yes#no#p' /etc/xinetd.d/rsync
# disable = yes 改成 disable = no
service xinetd restart
chkconfig xinetd on
chkconfig rsync on
}|| {
#centos
systemctl restart rsyncd
systemctl enable rsyncd >/dev/null >&
}
#
netstat -antp|grep
[[ $? == ]] && { echo "#rsync服务已启动……";exit ; }
echo "#查看列表"
rsync --list-only rsync://test@127.0.0.1
[[ `grep $(hostname) /etc/hosts|wc -l` == ]] && echo "#需要把hostname添加到/etc/hosts"
} ### rsync同步客户端(备份源)
function rs_c() {
echo "#安装……"
[[ `rpm -qa rsync|wc -l` == ]] && { yum install rsync -y; } || echo "rsync 已安装" echo "#查看列表"
rsync --list-only rsync://test@$RS_IP echo "rsync2017">/etc/rsync.pwd
echo "test2017">/etc/rsync.ps
chmod /etc/rsync.ps
chmod /etc/rsync.pwd } ###Lsync实时同步,客户端(备份源)
function lsync_c() {
mkdir -p $Source
echo "#Lsync安装配置"
[[ `rpm -qa epel-release|wc -l` == ]] && { yum install epel-release -y; }
[[ `rpm -qa lsyncd|wc -l` == ]] && { yum install lsyncd -y; } || echo "lsyncd 已安装"
[[ `rpm -qa lua lua-devel|wc -l` != ]] && { yum install lua lua-devel -y; } || echo "lua 已安装"
echo '
-- #全局配置
settings {
logfile ="/var/log/lsyncd.log",
statusFile = "/tmp/lsyncd.stat",
statusInterval = ,
inotifyMode = "CloseWrite or Modify",
maxProcesses = ,
maxDelays = ,
} -- #远程目录实时同步,rsync模式
sync {
default.rsync,
source = "'$Source'",
target = "'$Target'",
delete = running,
exclude = { ".*",".tmp" },
delay = ,
init = false,
-- #默认 true 当init = false ,只同步启动后发生改动事件
rsync = {
binary = "/usr/bin/rsync",
archive = true,
compress = true,
verbose = true,
copy_links = true,
password_file = "/etc/rsync.ps",
-- _extra = {"--bwlimit=200"}
}
} -- 本地目录同步测试,rsync模式
sync {
default.rsync,
source = "/tmp/src",
target = "/tmp/dest",
delay = ,
rsync = {
binary = "/usr/bin/rsync",
archive = true,
compress = false,
--bwlimit =
}
}
'>/etc/lsyncd.conf #创建测试目录
mkdir /tmp/{src,dest} >/dev/null >&
#启动服务
[[ `uname -r` == *el6* ]] && {
service lsyncd restart
chkconfig lsyncd on
} || {
systemctl restart lsyncd
systemctl enable lsyncd >/dev/null >&
}
[[ `ps -ef|grep lsync|grep -v grep|wc -l` == ]] && {
echo 'Lsync启动成功……'
echo "本地目录同步测试"
echo "rm -f /tmp/{src,dest}/ #清空目录"
rm -f /tmp/{src,dest}/*
echo "touch /tmp/src/luck-{1..8}.txt #创建文件,测试同步"
touch /tmp/src/luck-{1..8}.txt
sleep 2
echo "#查看同步"
echo "ls -l /tmp/src";ls -l /tmp/src
echo "ls -l /tmp/dest";ls -l /tmp/dest
} || {
echo 'Lsync启动失败……'
echo "请检查配置文件 /etc/lsyncd.conf "
}
} function rs_help() {
echo "
# rsync -a参数 源 目标
#rsync -avzP --delete /root/test/ /www/backup/test/
#查看列表
rsync --list-only rsync://test@$RS_IP
#测试,拉取
rsync -avzP --delete --password-file=/etc/rsync.pwd test@$RS_IP::test /tmp/rsync/
#测试,推送
rm -rf /tmp/rsync/*
touch /tmp/rsync/abc{1..9}.txt
ll /tmp/rsync/
rsync -avzP --delete --password-file=/etc/rsync.pwd /tmp/rsync/ test@$RS_IP::backup
#使用ssh隧道
rsync -avzP -e ' ssh -p 22' root@$RS_IP:/www/backup/test/ /test/
#服务端设置固定IP
rsync --daemon --address=192.168.20.41
"
} ################
function mks() {
#Rsync编译安装参考
#建议先yum安装后,在编辑安装升级
cd /tmp
#wget https://download.samba.org/pub/rsync/src/rsync-3.1.2.tar.gz
tar xf rsync-3*.tar.gz
cd rsync-3*
./configure
make && make install
#替换yum安装文件/usr/bin/rsync
[[ -f /usr/bin/rsync ]] && {
mv /usr/bin/rsync /usr/bin/rsyncd
ln -s /usr/local/bin/rsync /usr/bin/rsync
/usr/bin/rsync --version|head -1
} || {
/usr/bin/rsync --version|head -1
}
}
################ case "$1" in
"s")
rs_s
exit
;;
"c")
rs_c
exit
;;
"l")
rs_c
lsync_c
exit
;;
"h")
rs_help
exit
;;
*)
echo " $0 + { s|c|l|h }"
echo " s #安装Rsync服务端"
echo " c #安装Rsync客户端"
echo " l #安装Rsync+Lsync实时同步客户端"
echo " h #rsync 同步示例"
exit
;;
esac
Rsync同步、Rsync+Lsync实时同步的更多相关文章
- Linux下Rsync+sersync实现数据实时同步
inotify 的同步备份机制有着缺点,于是看了sersync同步,弥补了rsync的缺点.以下转自:http://www.osyunwei.com/archives/7447.html 前言: 一. ...
- rsync+sersync实现文件实时同步
前言: 一.为什么要用Rsync+sersync架构? 1.sersync是基于Inotify开发的,类似于Inotify-tools的工具 2.sersync可以记录下被监听目录中发生变化的(包括增 ...
- CentOS 6.5 rsync+inotify实现数据实时同步备份
CentOS 6.5 rsync+inotify实现数据实时同步备份 rsync remote sync 远程同步,同步是把数据从缓冲区同步到磁盘上去的.数据在内存缓存区完成之后还没有写入到磁盘 ...
- sersync+rsync实现服务器文件实时同步
sersync+rsync实现服务器文件实时同步 一.为什么要用rsync+sersync架构? 1.sersync是基于inotify开发的,类似于inotify-tools的工具 2.sersyn ...
- sersync基于rsync+inotify实现数据实时同步
一.环境描述 需求:服务器A与服务器B为主备服务模式,需要保持文件一致性,现采用sersync基于rsync+inotify实现数据实时同步 主服务器A:192.168.1.23 从服务器B:192. ...
- Rsync+sersync实现数据实时同步
前言: 一.为什么要用Rsync+sersync架构? 1.sersync是基于Inotify开发的,类似于Inotify-tools的工具 2.sersync可以记录下被监听目录中发生变化的(包括增 ...
- Linux下Rsync+Inotify-tools实现数据实时同步
Linux下Rsync+Inotify-tools实现数据实时同步 注意:下面的三个案例都是rsync 每次都是全量的同步(这就坑爹了),而且 file列表是循环形式触发rsync ,等于有10个文件 ...
- CentOS7下Rsync+sersync实现数据实时同步
近期公司要上线新项目,后台框架选型我选择当前较为流行的laravel,运行环境使用lnmp. 之前我这边项目tp32+apache,开发工具使用phpstorm. 新建/编辑文件通过phpstorm配 ...
- Rsync+inotify实现文件实时同步#附shell脚本
强烈推荐先仔细看此文 https://segmentfault.com/a/1190000002427568 实验环境 centos 7.3 vm2:192.168.221.128 同步服务器 vm1 ...
随机推荐
- 从项目中总结的js知识点
1. 数字字符串和数字进行比较可以得出正确结果,却不能正确判断是否在一个数字数组中.如以下程序: var s = '8', n = 8, arr = [1,2,8,9]; console.log(s= ...
- Linux系统挂载操作mount详解
在Linux系统中,文件系统不挂载是无法使用的.挂载,即是让文件系统在操作系统中可用.在Linux中使用mount命令来挂载文件系统,有永久性挂载和临时性挂载两种挂载方式. 1. 永久性挂载: 修改配 ...
- Stack by pointer
前言:因为栈的很多操作是基于表的,所以这篇文章里的例程就不再大面积地写注释了,有不理解的地方可以翻看之前的链表笔记,或者直接写在评论区. 咳咳,说到这个栈,很多人乍听之下感觉很陌生.卧槽这是什么玩意. ...
- switchhost -- 切换host的工具
https://github.com/oldj/SwitchHosts/downloads 下载链接: 1,290 downloads SwitchHosts! _v0.2.2.1790.dmg - ...
- Hadoop 中 最重要的两个模块
Hadoop 中 最重要的两个模块 HDFS 分布式的文件系统 主节点: NameNode SecondaryNamenode ResourceManager 从节点: DataNode Node ...
- Mysql修改已有数据的字符集
Mysql修改已有数据的字符集 问题 在生产环境中跑了很久,发现MysqlClient连接的字符集是默认的latin1,我们一直以为都是utf8,造成这样的误解,是因为在内网环境中,我们是源码编译的M ...
- SSH框架的多表查询和增删查改 (方法一)中
原创作品,允许转载,转载时请务必标明作者信息和声明本文章==>http://www.cnblogs.com/zhu520/p/7774144.html 这边文章是接的刚刚前一遍的基础上敲的 ...
- 利用canvas 导出图片
1.使用canvas绘制图片,并将图片导出. 在本地直接访问静态网页时,无法使用toDataURL(),需要将网页发布后,canvas才能使用toDataURL获取画布上的内容.因为canvas不允许 ...
- [LeetCode] BFS解决的题目
一.130 Surrounded Regions(https://leetcode.com/problems/surrounded-regions/description/) 题目: 解法: 这道题 ...
- 数据库连接(Oracle/sqlServer增、删、改、查)
一.把数据库包导入项目中,并且Build path(oracle例如ojdbc6.jar;sqlServer例如sqljdbc.jar) 二.开始操作 1.普通连接: String className ...