lsyncd实时同步工具
简介
Lysncd 实际上是lua语言封装了 inotify 和 rsync 工具,采用了 Linux 内核(2.6.13 及以后)里的 inotify 触发机制,然后通过rsync去差异同步,达到实时的效果。
完美解决了 inotify + rsync海量文件同步带来的文件频繁发送文件列表的问题 —— 通过时间延迟或累计触发事件次数实现。
环境
由于成本考虑,没有用ELK来做日志手机。需要采用lsyncd将每台服务器的/data/log/tomcat目录同步到固定的机器,使用Nginx来做日志展示。
服务器列表
| 系统 | ip | ssh端口 | 目录 | 注释 |
|---|---|---|---|---|
| CentOS 6.9 | 192.168.31.7 | 27 | /data/log/tomcat | 安装lsync |
| CentOS 6.9 | 192.168.31.216 | 27 | /data/log/tomcat/192.168.31.7 | 安装rsync |
备注:将192.168.31.7的/data/log/tomcat目录同步到192.168.31.216的/data/log/tomcat/192.168.31.7目录
拓扑图

说明:
将每台web服务器的日志/data/log/tomcat,使用rsync工具,通过ssh协议,发送给日志服务器。
ssh免密
注意:设置单向的ssh免密即可。也就是192.168.31.7能免密登录192.168.31.216
生成秘钥
2台服务器,都执行命令:
ssh-keygen -t rsa
copy秘钥
登录192.168.31.7,执行命令:
ssh-copy-id -i ~/.ssh/id_rsa.pub "-p 27 root@192.168.31.216"
安装lsyncd
有2种方法可以安装,主要讲解源码安装
yum安装
yum安装,前提是安装了epel更新源。使用命令:yum install -y lsyncd
源码安装
github下载,地址为:https://github.com/axkibe/lsyncd
本文采用的是源码安装方式,因为版本是比yum安装要新一点
安装依赖
编译环境
yum install -y gcc psmisc gcc-c++ cmake
安装lua
yum install -y lua lua-devel
安装其他组件
注意:rsync必须要安装
yum install -y rsync unzip
编译安装
mkdir -p /data/
unzip lsyncd-master.zip -d /usr/src/
cd /usr/src/lsyncd-master/
cmake -DCMAKE_INSTALL_PREFIX=/data/lsyncd
make && make install
创建同步目录
登录192.168.31.7,执行命令:
mkdir -p /data/log/tomcat
touch /data/log/tomcat/.txt
登录192.168.31.216,执行命令:
mkdir -p /data/log/tomcat/192.168.31.7
安装rsync
注意:server端和client端都需要安装rsync
登录192.168.31.7和192.168.31.216,执行命令:
yum install -y rsync
配置文件
cd /data/lsyncd
mkdir etc var
cd etc/
vi lsyncd.conf
内容如下:
settings {
--pid文件
logfile = "/data/lsyncd/var/lsyncd.log",
--状态文件
statusFile = "/data/lsyncd/var/lsyncd.status",
--同步模式,意思就是有更新就同步
inotifyMode = "CloseWrite or Modify",
--最大8个进程
maxProcesses = ,
}
--需要同步服务器的IP地址池
servers = {
"192.168.31.216",
}
--使用for循环遍历IP池
for _, server in ipairs(servers) do
sync {
--本地目录间同步,使用rsync
default.rsync,
--同步的源目录,使用绝对路径
source = "/data/log/tomcat",
--定义目的地址,注意:冒号后面是绝对路径
target = server..":/data/log/tomcat/192.168.31.7",
--累计事件,等待rsync同步延时时间。这里设置0秒,表示实时同步。
delay = ,
rsync ={
--rsync命令的绝对路径
binary ="/usr/bin/rsync",
archive =true,
compress =true,
verbose = true,
--使用ssh协议连接到目标服务器,如果端口不是22,请修改一下。
rsh = "/usr/bin/ssh -p 22 -o StrictHostKeyChecking=no"
},
}
end
启动服务
/data/lsyncd/bin/lsyncd /data/lsyncd/etc/lsyncd.conf
查看日志
tail -f /data/lsyncd/var/lsyncd.log
输出:
sent bytes received bytes 274.00 bytes/sec
total size is speedup is 0.00
Mon Oct :: Normal: Finished a list after exitcode:
查看进程
# ps -aux|grep lsync Warning: bad syntax, perhaps a bogus '-'? See /usr/share/doc/procps-3.2./FAQ
root 0.0 0.0 ? Ss : : /data/lsyncd/bin/lsyncd /data/lsyncd/etc/lsyncd.conf
root 0.0 0.0 pts/ S+ : : grep lsync
查看同步目录
登录到192.168.31.216,查看目录是否同步过来了
# ls /data/log/tomcat/192.168.31.7/ .txt
开机启动脚本
vi /etc/init.d/lsyncd
内容如下:
#!/bin/bash
#
# chkconfig: -
# description: Lightweight inotify based sync daemon
#
# processname: lsyncd
# config: /data/lsyncd/etc/lsyncd.conf
# config: /etc/sysconfig/lsyncd
# pidfile: /data/lsyncd/var/lsyncd.pid
# Source function library
. /etc/init.d/functions
# Source networking configuration.
. /etc/sysconfig/network
# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit
LSYNCD_OPTIONS="-pidfile /data/lsyncd/var/lsyncd.pid /data/lsyncd/etc/lsyncd.conf"
if [ -e /etc/sysconfig/lsyncd ]; then
. /etc/sysconfig/lsyncd
fi
RETVAL=
prog="lsyncd"
thelock=/var/lock/subsys/lsyncd
start() {
[ -f /data/lsyncd/etc/lsyncd.conf ] || exit
echo -n $"Starting $prog: "
if [ $UID -ne ]; then
RETVAL=
failure
else
daemon ${LSYNCD_USER:+--user ${LSYNCD_USER}} /data/lsyncd/bin/lsyncd $LSYNCD_OPTIONS
RETVAL=$?
[ $RETVAL -eq ] && touch $thelock
fi;
echo
return $RETVAL
}
stop() {
echo -n $"Stopping $prog: "
if [ $UID -ne ]; then
RETVAL=
failure
else
killproc lsyncd
RETVAL=$?
[ $RETVAL -eq ] && rm -f $thelock
fi;
echo
return $RETVAL
}
reload(){
echo -n $"Reloading $prog: "
killproc lsyncd -HUP
RETVAL=$?
echo
return $RETVAL
}
restart(){
stop
start
}
condrestart(){
[ -e $thelock ] && restart
return
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
restart
;;
reload)
reload
;;
condrestart)
condrestart
;;
status)
status lsyncd
RETVAL=$?
;;
*)
echo $"Usage: $0 {start|stop|status|restart|condrestart|reload}"
RETVAL=
esac
exit $RETVAL
增加启动项
chkconfig --add lsyncd
chkconfig --level lsyncd on
如果遇到不同步的情况:
.检查几台服务器是否存在文件/usr/bin/rsync
.检查source和target文件目录是否存在
.检查iptables和selinux是否关闭
.检查几台服务器之间是否做了秘钥认证,能够无密码ssh登录
本文参考链接:
https://linux.cn/article-5849-1.html
lsyncd实时同步工具的更多相关文章
- lsyncd 实时同步
1. 几大实时同步工具比较 1.1 inotify + rsync 最近一直在寻求生产服务服务器上的同步替代方案,原先使用的是inotify + rsync,但随着文件数量的增大到100W+,目录下的 ...
- lsyncd实时同步搭建指南——取代rsync+inotify
1. 几大实时同步工具比较 1.1 inotify + rsync 最近一直在寻求生产服务服务器上的同步替代方案,原先使用的是inotify + rsync,但随着文件数量的增大到100W+,目录下的 ...
- Lsyncd实时同步搭建指南
linux文件实时同步: inotify+rsync.sersync.lsyncd工具比较 一.inotify + rsync 最近一直在寻求生产服务服务器上的同步替代方案,原先使用的是inotify ...
- sersync/lsyncd实时同步
第一章 sersync/lsync实时同步 1.1 实时同步服务原理/概念 1)需要部署好rsync守护进程服务,实现数据传输 2)需要部署好inotify服务,实现目录中数据变化监控 3)将rsyn ...
- lsync目录文件实时同步工具
参考文档:https://vastxiao.github.io/article/2017/09/02/Linux/lsyncd_usage/ 防止连接丢失,已保存至百度网络-郑州-XXXXX 建议首先 ...
- sersync 实时同步工具
出处:http://code.google.com/p/sersync/ 当前版本的sersync依赖于rsync进行同步.如下图所示,在同步主服务器上开启sersync,将监控路径中的文件同步到目标 ...
- mongo 实时同步工具 mongosync
文档地址:https://github.com/Qihoo360/mongosync/wiki/%E4%BD%BF%E7%94%A8%E6%A0%B7%E4%BE%8B #数据全量备份mongodum ...
- 如何使用 lsyncd 实时同步并执行 shell 命令
修改 lsyncd 的默认配置,不直接执行rsync 进行同步,而是改用自己的脚本. binary 指定我们的脚本 vim /usr/local/lsyncd/etc/lsyncd.conf sett ...
- lsyncd —— 多机器实时同步文件神器
lsyncd 是一个支持实时.双向.多机器的多模式文件同步工具. 使用 Lua 语言封装了 inotify 和 rsync 工具,采用了 Linux 内核(2.6.13 及以后)里的 inotify ...
随机推荐
- 假设检验总结以及如何用python进行假设检验(scipy)
几种常见的假设检验总结如下: 假设检验名称 Z检验 t检验 χ2检验 F检验 原假设 H0: μ≥μ0 H0: μ≤μ0 H0: μ=μ0 (比较样本和总体均值) ...
- LSF 作业系统常用命令
LSF(Load Sharing Facility)是一个被广泛使用的作业管理系统,具有高吞吐.配置灵活的优点.通过 LSF 集中监控和调度,可以充分利用计算机的CPU.内存.磁盘等资源. bqueu ...
- 初识RSA
基础知识:http://www.guideep.com/read?guide=5676830073815040# python实现:https://blog.csdn.net/bian_h_f6127 ...
- 【Gamma阶段】第四次Scrum Meeting
冰多多团队-Gamma阶段第四次Scrum会议 工作情况 团队成员 已完成任务 待完成任务 卓培锦 修改可移动button以及button手感反馈优化 编辑器风格切换(夜间模式) 牛雅哲 修复bug并 ...
- 从 SVN 迁移至 Git 并保留所有 commit 记录
yum install -y git-svn 用户映射文件user.txt,等号左边为svn账号,右边为Git用户名和邮箱.注意:svn中有多少用户就要映射多少 test1=test1<1472 ...
- odoo开发笔记 -- 单台物理服务器上,利用docker部署多套odoo应用
部署结构: 待更新! ----服务器硬件配置: 操作系统:ubuntu16.04-64bit CPU/内存:4核8G 1. 基础环境安装 nginx离线安装: docker环境安装: 2. 官方容器镜 ...
- golang几种常用配置文件使用方法总结(yaml、toml、json、xml、ini)
原文连接: https://blog.csdn.net/wade3015/article/details/83351776 yaml配置文件的使用方法总结 首先介绍使用yaml配置文件,这里使用的是g ...
- SpringCloud 微服务中 @Async 注解自定义线程池 引发的aop 问题
背景 在 使用springCloud 的@Async注解来做异步操作时,想自定义其线程池. 引发问题 自定义完线程池后,发现代码里并没有使用自定义线程池里的线程,于是新建一个demo工程,一样的配置代 ...
- CISCO DHCP全攻略详解
原文链接地址:https://bbs.51cto.com/thread-800321-1.html 最近看到大家经常由于DHCP的问题犯愁, 为了让大家更明白的了解DHCP并且会配置,特此发这个贴 相 ...
- PMP模拟错题总结
本打算15天完成第二轮复习的,结果项目太忙,拖成了25天.第二轮主要以小绿书为主,就是如下这本 怎么说呢,题目偏向于考ITTO的内容,情景题比较少.可以使用“管理圈”APP作为补充 1.敏感性分析的结 ...