提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


文章目录

  • 前言
  • 一、Rsync是什么?
  • 二、背景说明
  • 三、配置步骤
  • 1.server端(192.168.5.246)
  • 2.Rsync-Backup端(192.168.5.222)



前言

待添加~


提示:以下是本篇文章正文内容,下面案例可供参考


一、Rsync是什么?


待添加~


二、背景说明


老王公司有一台Linux主机是专门用来运作网站的,这台Linux负责存储网站的日常产生的各种数据,称为server端。现在需要从server端同步网站的数据,也就是备份数据到另一台Linux,这台用来作备份的主机叫Rsync-Backup端。以下是入门实现步骤。


三、配置步骤


1.server端(192.168.5.246)


(1)关闭防火墙,保证两台主机ping通

[root@server ~]# systemctl  stop firewalld
[root@server ~]# setenforce 0
[root@server ~]# ping 192.168.5.222
PING 192.168.5.222 (192.168.5.222) 56(84) bytes of data.
64 bytes from 192.168.5.222: icmp_seq=1 ttl=64 time=1.06 ms
64 bytes from 192.168.5.222: icmp_seq=2 ttl=64 time=0.535 ms
64 bytes from 192.168.5.222: icmp_seq=3 ttl=64 time=0.746 ms
64 bytes from 192.168.5.222: icmp_seq=4 ttl=64 time=0.834 ms
64 bytes from 192.168.5.222: icmp_seq=5 ttl=64 time=0.560 ms
64 bytes from 192.168.5.222: icmp_seq=6 ttl=64 time=0.513 ms
^Z
[1]+  Stopped                 ping 192.168.5.222
[root@server ~]#

(2)安装Rsync

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

(3)安装完Rsync后,在/etc下会生成rsyncd.conf配置文件,打开配置文件进行配置(有关配置信息的详细解释,在以后会补充在文章后面,目前是先学会使用Rsync)

[root@server ~]# ll /etc/rsync*      
-rw-r--r--. 1 root root 458 Apr  1  2020 /etc/rsyncd.conf
[root@server ~]# vim /etc/rsyncd.conf

进入文件可以发现有一些全局变量的模板,可以删除掉,添加以下配置信息,并保存退出。

#Global Settings 
uid = root
gid = root 
use chroot = no
max connections = 20
secrets file = /etc/rsync.password
log file = /var/log/rsyncd.log 
pid file = /var/run/rsyncd.pid 
lock file = /var/run/rsync.lock
comment = hello world 
#motd file = /etc/rsyncd.motd 

[www]  
path = /mnt/www/
auth users = oldwang 
read only = no 
hosts allow = 192.168.5.222 
#hosts deny = 0.0.0.0/0.0.0.0
list = true 
ignore errors

说明:hosts allow = 192.168.5.222 ,指定的是允许该IP远程备份Server端的数据,也就是说想让哪台linux备份server端的数据就添加哪台Linux的IP进来,还可以添加一整个网段的IP进来。

(4)刚才写的配置信息中,我们指定了密码文件,那现在我们需要创建它。

[root@server ~]# vim /etc/rsync.password

在里面添加oldwang:123456,也就是刚才所写配置文件中auth users = oldwang 指定的虚拟用户名,以及密码。参考如下所示。

[root@server ~]# cat /etc/rsync.password 
oldwang:123456

给文件设置权限

[root@server ~]# chmod 600 /etc/rsync.password

(5)新建配置文件中指定的备份的目录(path = /mnt/www/)

[root@server ~]# mkdir /mnt/www

(6)复制一些测试文件到指定的备份目录,方便等会测试

[root@server www]# cp -r /usr/local/* /mnt/www/
[root@server www]# ls
bin  etc  games  include  lib  lib64  libexec  nagios  sbin  share  src

(7)启动Rsync(下面显示进程已运行)

[root@server www]# rsync --daemon --config=/etc/rsyncd.conf
[root@server www]# netstat -ptln | grep 873
tcp        0      0 0.0.0.0:873             0.0.0.0:*               LISTEN      77496/rsync         
tcp6       0      0 :::873                  :::*                    LISTEN      77496/rsync

2.Rsync-Backup端(192.168.5.222)


(1)关闭防火墙,保证两台主机ping通

[root@rsync-backup ~]# systemctl stop firewalld
[root@rsync-backup ~]# setenforce 0

(2)安装Rsync

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

(3)进行测试(只在Rsync-Backup端输入测试脚本)

1)下面的命令是从server端指定的备份目录下拉取内容到Rsync-Backup端的/mnt/目录下,也就是在Rsync-Backup端盗取Server端指定目录下的数据。执行下面命令后会出现输入密码,这个密码是Server端/etc/rsync.password这个文件中指定用户的密码。刚才设置的密码是123456。输入密码后完成数据传输同步。

[root@rsync-backup ~]# rsync -avzP oldwang@192.168.5.246::www /mnt
[root@rsync-backup ~]# ls /mnt
bin  etc  games  include  lib  lib64  libexec  nagios  sbin  share  src

可以看到东西已经传过来了

2)下面的命令是从Rsync-Backup端把任意指定目录的内容推送到Server端的rsync指定目录下,也就是在Rsync-Backup端发送自己的数据给Server端指定目录下。执行下面命令后会出现输入密码,这个密码是Server端/etc/rsync.password这个文件中指定用户的密码。刚才设置的密码是123456。输入密码后完成数据传输同步。传输完毕,请到Server端,ls查看/mnt/www目录下的内容,就会发现从Rsync-Backup端发送过来新增的数据。

[root@rsync-backup ~]#rsync -avz /usr/local/share/ oldwang@192.168.5.246::www

3)上面两条测试命令都需要输入密码,可以在Rsync-Backup端下,随便建一个密码文件。

[root@rsync-backup ~]# echo "123456" > /etc/rsync.password
[root@rsync-backup ~]# chmod 600 /etc/rsync.password

添加完毕之后,可以在脚步命令后面添加–password-file=/etc/rsync.password就可以不用输入密码便可以进行数据同步传输。示例如下:

[root@rsync-backup ~]#rsync -avz /usr/local/share/ oldwang@192.168.5.246::www  --password-file=/etc/rsync.password
[root@rsync-backup ~]#rsync -avzP oldwang@192.168.5.246::www /mnt  --password-file=/etc/rsync.password