我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Linux数据实时同步(sersync+rsync)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Linux数据实时同步(sersync+rsync)

需求:由于单台服务器存储着所有的文件,为了防止服务器故障导致文件丢失或者损坏,先将Master(175)/var/ftp/pub/的目录文件实时备份到Slave(176)/backup/目录下。

环境:

说明:

Rsync可以远程同步,支持本地复制,实时同步需要借助第三方工具sersync/inotify

Sersync可以记录下被监听目录中发生变化的(包括增加、删除、修改)具体某一个文件或者某一个目录的名字,然后使用rsync同步的时候

Inotify只能记录下被监听的目录发生了变化(增,删,改)并没有把具体是哪个文件或者哪个目录发生了变化记录下来

步骤:

一、Slave服务器配置

1.在Slave服务器上安装Rsync

[root@slave ~]# yum -y install rsync

2.在Slave服务器上配置rsync

[root@slave ~]# vim /etc/rsyncd.conf
uid = root
gid = root
use chroot = no
max connections = 36000
timeout = 600
pid file =/var/run/rsyncd.pid
lock file =/var/run/rsync.lock
log file = /var/log/rsyncd.log
ignore errors = no
read only = no
list = no
hosts allow = 192.168.1.175
hosts deny = *
auth users = rsync_backup
secrets file =/etc/rsync.password
[backup]
path = /backup/sersync/

# 配置注解:
# uid:指定传输文件时的用户
# gid:指定传输文件时的组
# use chroot true|false:表示在传输文件前首先chroot到path参数所指定的目录下,可以实现安全防护,但缺点是需要以root权限,并且不能备份指向外部的符号连接所指向的目录文件,默认情况下chroot值为true
# max connections:指定最大的连接数,默认是0,即没有限制
# read only ture|false:如果为true,则不能上传到该模块指定的路径下
# list:表示当用户查询该服务器上的可用模块时,该模块是否被列出,true为列出,false为隐藏
# auth users:指定传输时要使用的用户名
# secrets file:指定密码文件,注意该密码文件的权限一定要是600,格式:用户名:密码
# hosts allow:是允许同步的主机,可以是IP或者网段,如果是多个中间用空格隔开
# hosts deny:拒绝同步的主机,可以是IP或者网段,如果是多个中间用空格隔开
# [backup]:同步的模块名
# path:同步的路径

3.创建同步的用户与密码的文件

即rsyncd.conf中secrets file这个配置选项中的文件/etc/rsync.passwd,同进要设置rsync.password的权限为600

[root@slave ~]# echo "rsync_backup:123456" >/etc/rsync.password
[root@slave ~]# chmod 600 /etc/rsync.password

4.创建同步的目录

即rsyncd.conf中path配置选项中的目录

[root@slave ~]# mkdir -p /backup/sersync

5.启动守护进程,并写入开机自启动

[root@slave ~]# rsync --daemon --config=/etc/rsyncd.conf 
[root@slave ~]# echo "rsync --daemon --config=/etc/rsyncd.conf" >>/etc/rc.local
[root@slave ~]# chmod +x /etc/rc.d/rc.local
[root@slave ~]# tail -1 /etc/rc.local
[root@slave ~]# reboot
[root@slave ~]# systemctl status rc-local.service
[root@slave ~]# netstat -ntlp | grep rsync

二、Master服务器配置

1.在Master安装rsync

[root@master ~]# yum -y install rsync

2.首先创建master端的密码验证文件,同进要设置rsync.password的权限为600

[root@master ~]# echo 50000000 >/proc/sys/fs/inotify/max_user_watches
[root@master ~]# echo 327679 >/proc/sys/fs/inotify/max_queued_events
[root@master ~]# echo "123456" >/etc/rsync.password
[root@master ~]# chmod 600 /etc/rsync.password

3.测试rsync

[root@master ~]# rsync -avzP /var/ftp/pub/sersync/ rsync_backup@192.168.1.176::backup --password-file=/etc/rsync.password

4.部署sersync,下载地址

[root@master ~]# mkdir /usr/local/sersync/
[root@master ~]# mkdir /usr/local/sersync/bin
[root@master ~]# mkdir /usr/local/sersync/conf
[root@master ~]# mkdir /usr/local/sersync/logs
[root@master sersync]# wget https://raw.githubusercontent.com/orangle/sersync/master/release/sersync2.5.4_64bit_binary_stable_final.tar.gz
[root@master sersync]# tar xvf sersync2.5.4_64bit_binary_stable_final.tar.gz
[root@master sersync]# mv GNU-Linux-x86/sersync2 ./bin/sersync
[root@master sersync]# mv GNU-Linux-x86/confxml.xml ./conf/
[root@master conf]# cp confxml.xml confxml.xml.bak
[root@master sersync]# tree sersync

5.修改config.xml文件,建议拷贝一份在修改,需要把监控的目录数据同步到master指定的模块下,前面写了slave的模块名是backup对应的目录是:/backup/

[root@master sersync]# vim conf/confxml.xml
# 如果系统linux7以上,需要将xfs="false"修改成xfs="true",否则sersync无法递归监控
<fileSystem xfs="true"/>
<localpath watch="/var/ftp/pub/sersync">
	<remote ip="192.168.1.176" name="backup"/>
</localpath>
# 指定rsync的虚拟用户和密码文件路径
<rsync>
	<commonParams params="-artuz"/>
	<auth start="true" users="rsync_backup" passwordfile="/etc/rsync.password"/>
	<userDefinedPort start="false" port="874"/><!-- port=874 -->
	<timeout start="false" time="100"/><!-- timeout=100 -->
	<ssh start="false"/>
</rsync>
[root@master sersync]# echo "export PATH=$PATH:/usr/local/sersync/bin/" >>/etc/profile
[root@master sersync]# source /etc/profile
[root@master sersync]# which sersync

6.启动sersync

[root@master sersync]# bin/sersync -d -r -o /usr/local/sersync/conf/confxml.xml
# 参数注解:
# -d:启用守护进程模式
# -r:在监控前,将监控目录与远程主机用rsync命令推送一遍
# -o:指定配置文件,默认使用confxml.xml文件

7.测试同步,在master服务器需要同步的目录下创建文件及目录

[root@master sersync]# cd /var/ftp/pub/sersync/
[root@master sersync]# touch {1..100}
[root@master sersync]# mkdir note
[root@slave backup]# ls

8.加入开机启动项,重启服务器查看

[root@master ~]# ln -s  /usr/local/sersync/bin/sersync /usr/local/bin/sersync
[root@master ~]# echo "sersync -d -r -o /usr/local/sersync/conf/confxml.xml" >>/etc/rc.local
[root@master ~]# chmod +x /etc/rc.d/rc.local
[root@master ~]# systemctl status rc-local.service
[root@master ~]# tail -1 /etc/rc.local
[root@slave ~]# reboot

9.加入开机启动后测试同步,在master增加、删除、修改文件及目录,查看slave是否实时同步

[root@master sersync]# cd /var/ftp/pub/sersync/
[root@master sersync]# touch {1..100}
[root@master sersync]# mkdir note
[root@master sersync]# rm -rf ./*
[root@slave backup]# ls


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Linux数据实时同步(sersync+rsync)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Linux数据实时同步(sersync+rsync)

需求:由于单台服务器存储着所有的文件,为了防止服务器故障导致文件丢失或者损坏,先将Master(175)/var/ftp/pub/的目录文件实时
2023-05-16

rsync实时同步

与传统的cp、tar备份方式相比,rsync具有安全性高、备份迅速、支持增量备份等优点,通过rsync可以解决对实时性要求不高的数据备份需求,例如定期的备份文件服务器数据到远端服务器,对本地磁盘定期做数据镜像等。192.168.0.1 源服
2023-06-05

Linux数据同步工具rsync怎么用

这篇文章主要讲解了“Linux数据同步工具rsync怎么用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux数据同步工具rsync怎么用”吧!讲解 rsync 用法之前,为了让大家对此
2023-06-27

python rsync 数据同步脚本

#!/usr/bin/env python# -*- coding: utf-8 -*-import pexpectimport timeimport tracebackdef doRsync(user,passwd,ip,srcDir,d
2023-01-31

Linux 通过Rsync+Inotify实现本、异地远程数据实时同步功能

0x0 测试环境 总部生产服务器与分部备份服务器要求实现异地数据备份,环境如下**centos 6.5** 生产服务器目录: /home/zytest/files 备份服务器目录: /home/zytest/files 用户 / 密码: z
2022-06-03

Linux中使用数据备份同步工具Rsync的操作方法

Linux中使用数据备份同步工具Rsync的操作方法,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。对于运维人员来说,数据备份是最重要的工作之一,rsync就是一款通过网络备
2023-06-12

rsync+inotify如何实现多台web数据动态同步操作

这篇文章主要介绍了rsync+inotify如何实现多台web数据动态同步操作,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。*背景:由于无存储共享设备,web集群中的代码均存
2023-06-13

linux 中怎么利用rsync实现文件增量同步

这篇文章给大家介绍linux 中怎么利用rsync实现文件增量同步,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、系统环境:更新源服务器:192.0.2.20目的服务器:192.0.2.21 二、目的服务器配置:1
2023-06-06

怎么用Linux系统中的rsync实现文件同步

这篇文章主要介绍了怎么用Linux系统中的rsync实现文件同步的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么用Linux系统中的rsync实现文件同步文章都会有所收获,下面我们一起来看看吧。在Linux系
2023-06-28

mongodb实时数据同步怎么实现

要实现MongoDB的实时数据同步,可以使用MongoDB的Change Streams功能。Change Streams允许应用程序监视集合中数据的变化,并在数据变化时触发相应的操作。具体步骤如下:在MongoDB中创建Change S
mongodb实时数据同步怎么实现
2024-04-10

阿里云MySQL数据库实时同步

在当今的信息时代,数据是企业的生命线,而数据库则是数据存储和管理的关键。如何保证数据库数据的安全、稳定和实时性,成为企业面临的重要问题。而阿里云的MySQL数据库实时同步服务,正好解决了这个问题。一、问题提出随着企业的业务不断扩大,数据量也在不断增加,如果数据没有及时同步,就可能出现数据丢失、数据冲突等问题,影响
阿里云MySQL数据库实时同步
2023-10-29

Linux怎么实现本、异地远程数据实时同步功能

这期内容当中小编将会给大家带来有关Linux怎么实现本、异地远程数据实时同步功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。0x0 测试环境总部生产服务器与分部备份服务器要求实现异地数据备份,环境如下*
2023-06-05

编程热搜

目录