如何通过rsync+sersync 实现同步备份

该文档是在很早之前写的,一直存在草稿箱中,最近在整理其它学习资料时发现还没有发布,内容和方法有可能和现在的操作系统版本有些不符合了,但处理思路没有变化,大家可以根据最新版本要求,参照该文档进行配置学习,有些不对的地方还望大家多多理解。

一、为什么要实现同步备份

服务器上有些重要文件或数据时,可以把他们多备份一份到其他服务器上,这样就不怕数据或文件丢失了。

二、环境的搭建

**服务器A:**192.168.1.10 源服务器

**服务器B:**192.168.1.20 目的服务器

我们要实现的就是把A服务器上的文件同步到B服务器上,从而实现备份。我们主要是在B服务器上安装配置rsync,在A服务器上安装配置sersync,通过sersync把文件推送到B服务器上

三、开始搭建

3.1、配置B服务器

3.1.1、关闭selinux

在/etc/sysconfig/selinux 这个文件,设置SELINUX=disable

3.1.2、防火墙开通873端口

可以使用以下命令,也可以把防火墙关闭

-A INPUT -m state --state NEW -m tcp -p tcp --dport 873 -j ACCEPT

3.1.3、开始安装rsync
bash 复制代码
[root@Test ~]# yum install rsync -y
3.1.4、配置rsync

rsync的配置文件是/etc/rsyncd.conf,配置如下:

bash 复制代码
#Gobal Setting

uid = root

gid = root

use chroot = no

read only = no

hosts allow = 192.168.1.0/24

hosts deny = *

max connections = 5

pid file = /var/run/rsyncd.pid

secrets file = /etc/rsyncd/rsyncd.password

log file = /var/log/rsyncd.log

motd file = /etc/rsyncd/rsyncd.motd

transfer logging = yes

log format = %t %a %m %f %b

ignore errors = yes

#User Options

[test]

path=/test

list = yes

auth users = tom1

comment = Tom1's home

secrets file:这个是配置同步密码文件的。

test\]:这个是配置同步模块的名称 path:是配置同步的目录 hosts allow:是允许同步的主机 hosts deny:拒绝同步的主机。 ##### 3.1.5、创建同步的用户与密码的文件 即上图中的secrets file这个配置选项中的文件。/etc/rsync.passwd,同进要设置这个文件的权限为600 ```bash [root@Test ~]# echo "user:password" >> /etc/rsync.passwd [root@Test ~]# chmod 600 /etc/rsync.passwd ``` ##### 3.1.6、创建同步的目录 即上图中path配置选项中的目录。 ```bash [root@Test ~]# mkdir /home/rsynctest ``` ##### 3.1.7、启动rsync ```bash [root@Test ~]# rsync --daemon --config=/etc/rsyncd.conf ``` 接着重启一下xinetd ```bash [root@Test ~]# /etc/init.d/xinetd restart ``` ##### 3.1.8、配置开机启动 ```bash [root@Test ~]# echo "rsync --daemon --config=/etc/rsyncd.conf" >> /etc/rc.d/rc.local ``` 到这B服务器基本就配置完成了。 #### 3.2、配置A服务器 ##### 3.2.1、sersync官网下载sersync 官网地址:http://sersync.sourceforge.net ```bash [root@Test ~]# wget http://sersync.googlecode.com/files/sersync2.1_64bit_binary.tar.gz ``` ##### 3.2.1、安装sersync ```bash [root@Test ~]# mkdir /usr/local/sersync [root@Test ~]# mkdir /usr/local/sersync/conf [root@Test ~]# mkdir /usr/local/sersync/bin [root@Test ~]# mkdir /usr/local/sersync/log [root@Test ~]# tar zxvf sersync2.5_32bit_binary_stable_final.tar.gz [root@Test ~]# cd GNU-Linux-x86/ [root@Test ~]# cp confxml.xml /usr/local/sersync/conf [root@Test ~]# cp sersync2 /usr/local/sersync/bin ``` ##### 3.2.3、创建密码文件 同B服务器一样,不过这个文件只要保存一个密码就行了,不用用户名,权限也是600 ```bash [root@Test ~]# echo "password" >> /etc/rsync.passwd [root@Test ~]# chmod 600 /etc/rsync.passwd ``` ##### 3.2.4、配置sersync 配置文件就是上第二步复制的confxml.xml这个文中,路径在/usr/local/sersync/conf中。 ```bash # 设置本地IP和端口 # 开启DUBUG模式 # 开启xfs文件系统 # 同步时忽略推送的文件(正则表达式),默认关闭 # 设置要监控的事件 # 本地同步的目录路径 # 远程IP和rsync模块名 # rsync指令参数 # rsync同步认证 # 设置rsync远程服务端口,远程非默认端口则需打开自定义 # 设置超时时间 # 设置rsync+ssh加密传输模式,默认关闭,开启需设置SSH加密证书 # sersync传输失败日志脚本路径,每隔60会重新执行该脚本,执行完毕会自动清空。 # 设置rsync+crontab定时传输,默认关闭 # 设置sersync传输后调用name指定的插件脚本,默认关闭 # 插件脚本范例 # 插件脚本范例 ``` ##### 3.2.5、创建同步目录 ```bash [root@Test ~]# mkdir /home/rsynctest ``` ##### 3.2.6、设置环境变量 ```bash [root@Test ~]# echo "export PATH=$PATH:/usr/local/sersync/bin/" >> /etc/profile [root@Test ~]# source /etc/profile ``` ##### 3.2.7、启动sersync ```bash [root@Test ~]# sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml ``` 注:重启操作如下: ```bash [root@Test ~]# killall sersync2 && sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml ``` ##### 3.2.8、设置开机启动 ```bash [root@Test ~]# echo "sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml" >> /etc/rc.local ``` 好了,两台机器的配置都已经完成,现在你在A服务器的/home/rsynctest这个目录下创建文件,看看B服务器同样目录下是不是也生成了这个文件,如果是,那就恭喜,你成功了!

相关推荐
vortex51 小时前
探索 Shell:选择适合你的命令行利器 bash, zsh, fish, dash, sh...
linux·开发语言·bash·shell·dash
GalaxyPokemon1 小时前
LeetCode - 148. 排序链表
linux·算法·leetcode
懒羊羊大王呀2 小时前
Ubuntu20.04中 Redis 的安装和配置
linux·redis
鳄鱼杆2 小时前
服务器 | Centos 9 系统中,如何部署SpringBoot后端项目?
服务器·spring boot·centos
杰哥技术分享2 小时前
在 CentOS 上安装 Docker 和 Docker Compose 并配置使用国内镜像源
linux·docker·centos
知更鸟呆呆2 小时前
【Linux操作系统】基础开发工具(yum、vim、gcc/g++)
linux·运维·vim
xiangyong582 小时前
ubuntu系统文件误删(/lib/x86_64-linux-gnu/libc.so.6)修复方案 [成功解决]
linux·ubuntu·gnu
t198751283 小时前
Linux 上的 Tomcat 端口占用排查
linux·tomcat·firefox
小狗爱吃黄桃罐头3 小时前
正点原子[第三期]Arm(iMX6U)Linux移植学习笔记-12.1 Linux内核启动流程简介
linux·arm开发·学习
地衣君4 小时前
Ubuntu 配置使用 zsh + 插件配置 + oh-my-zsh 美化过程
linux·运维·ubuntu