CentOS7下使用Lsyncd实现文件实时同步

Lsyncd 在几秒钟内将这些文件事件整理核对后,然后生成一个或多个进程以将更改同步到远程文件系统。默认使用的同步方法是rsync。因此,Lsyncd 是一种轻量级的实时镜像解决方案。

CentOS7下使用Lsyncd实现文件实时同步

Lsyncd简单介绍

Lsyncd 使用文件系统事件接口(inotify 或 fsevents)来监视本地文件和目录的更改。

Lsyncd 在几秒钟内将这些文件事件整理核对后,然后生成一个或多个进程以将更改同步到远程文件系统。默认使用的同步方法是rsync。因此,Lsyncd 是一种轻量级的实时镜像解决方案。

Lsyncd 相对容易安装,不需要新的文件系统或块设备。Lysncd 不会影响本地文件系统的性能。作为 rsync 的替代方案,Lsyncd 还可以通过 rsync+ssh 推送更改。当文件或目录被重命名或移动到本地树中的新位置时,rsync+ssh 允许更有效的同步。(相比之下,plain rsync 通过删除旧文件然后重新传输整个文件来执行移动。)

Lsyncd 2.2.1 要求 rsync >= 3.1。

官方文档:

https://lsyncd.github.io/lsyncd/

下面介绍CentOS7下使用Lsyncd实现文件实时同步

  • 服务器A:192.168.31.230
  • 目标服务器B:192.168.31.60

需求:将A服务器上/var/log/nginx/目录下文件实时同步到B服务器中,并排除error.log*

1、A服务器上安装lsyncd

前提是有配置EPEL源。

yum install lsyncd
CentOS7下使用Lsyncd实现文件实时同步

2、A服务器配置到B服务器的免密登录

ssh-keygen -t rsa -b 4096
ssh-copy-id -p 8122 root@192.168.31.60
ssh -p 8122 root@192.168.31.60
CentOS7下使用Lsyncd实现文件实时同步

3、配置/etc/lsyncd.conf

mv /etc/lsyncd.conf /etc/lsyncd.conf_default
vi /etc/lsyncd_exclude.lst
vi /etc/lsyncd.conf
添加如下内容
/etc/lsyncd.conf
settings {
   logfile    = "/var/log/lsyncd/lsyncd.log",
   statusFile = "/tmp/lsyncd.status",
   insist = true,
   inotifyMode = "Modify",
   statusInterval = 1
}
sync {
   default.rsyncssh,
   source="/var/log/nginx/",
   host="192.168.31.60",
   targetdir="/data/logs_backup",
   excludeFrom="/etc/lsyncd_exclude.lst",
   maxDelays = 5,
   delay = 0,
   rsync = {
     archive = true,
     compress = false,
     -- verbose   = true
   },
   ssh = {
     port = 8122
   }
}

要排除error.log*。

vi /etc/lsyncd_exclude.lst 
error.log*
CentOS7下使用Lsyncd实现文件实时同步
CentOS7下使用Lsyncd实现文件实时同步

4、配置文件检查测试

lsyncd -nodaemon /etc/lsyncd.conf运行查看下是否有报错,如果有报错根据报错情况排查配置文件问题。

lsyncd -nodaemon /etc/lsyncd.conf

如下图所示,当curl http://192.168.31.230触发了access.log变动时会触发同步。

CentOS7下使用Lsyncd实现文件实时同步

如果没有报错直接退出后就可以使用systemctl start lsyncd启动lsyncd即可。

5、设置为服务后台运行

systemctl enable lsyncd.service
systemctl start lsyncd.service
tail -f /var/log/lsyncd/lsyncd.log
CentOS7下使用Lsyncd实现文件实时同步

以上就是使用Lsyncd实现文件自动同步的过程。

要比之前的文章记一次利用GrayLog实现采集与备份云服务器Web访问日志的实现过程的方式更简单。

文章来源:https://www.cnaaa.net,转载请注明出处:https://www.cnaaa.net/archives/10438

(0)
凯影的头像凯影
上一篇 2023年12月7日 下午3:17
下一篇 2023年12月8日 下午2:18

相关推荐

  • 多台服务器如何设置SSH免密登录

    本次测试需要服务器己安装好 ssh-keygen和ssh-copy-id。安装方式如下: 安装ssh-keygen和ssh-copy-id 1、在客户端机器上生成密钥,这里连续三个回车默认即可。 3、进入到/root/.ssh/目录下,查看是否生成密钥成功,这里一共生成三个文件,本次主要用到的是id_rsa.pub:私钥(本次实验用到的) 4、通过命令复制私…

    2022年6月16日
    1.8K00
  • 【Docker入门】数据卷管理

    在创建 docker 的镜像和容器后,还需要对容器进行数据管理,以便能与主机、不同容器之间进行交换数据。 本文主要介绍如何通过数据卷的方式实现多个容器间的数据共享和交换。 了解docker数据卷 docker 数据卷(Data Volume)是一个可供容器使用的特殊目录,它将主机操作系统目录直接映射进容器,类似于 Linux 的 mount 操作。数据卷可以…

    2024年2月2日
    1.2K00
  • Prometheus 监控进程

    prometheus 进程的监控 1. process exporter功能 2. 监控目标对主机进程的监控,chronyd sshd 等服务进程已经已定义脚本运行程序的运行状态监控。 process-compose的安装 监控所有进程 监控指定进程 docker 运行 docker ps -a 确认 up http://10.19.1.220:9256/m…

    2024年1月4日
    1.2K00
  • DM工作笔记-DATEADD(指定日期添加n个时间段)函数和其他时间函数

    达梦官方文档已经说得很清楚了,在此仅记录下笔记,方便以后进行查阅。 DATEADD对应的相关文档如下: 这里说明下CREATE_TIME是TIMESTAMP类型。 如下例子: 运行截图如下: 现在有个需求,让CREATE_TIME添加,2秒,2分钟,2小时,2年。 对应的SQL如下: 运行截图如下: 如果再有这样的一个需求,离现在(当前时刻)2小时外的数据是…

    2023年12月27日
    2.5K00
  • Windows主机入侵痕迹排查办法

    一、排查思路 在攻防演练保障期间,一线工程师在实施主机入侵痕迹排查服务时可能面临时间紧、任务急、需要排查的主机数量众多情况。为了确保实施人员在有限的时间范围内,可以高效且保证质量的前提下完成主机入侵痕迹排查工作,本人总结了自己的一些经验,下面的内容特此分享主机入侵痕迹排查服务中重点、关键的排查项,仅作为参考使用。 1.1初步筛选排查资产 一般情况下,客户资产…

    2023年3月3日
    1.7K00

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

在线咨询: QQ交谈

邮件:712342017@qq.com

工作时间:周一至周五,8:30-17:30,节假日休息

关注微信