Linux系统rsync实战操作

时间:2022-07-25
本文章向大家介绍Linux系统rsync实战操作,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

Linux系统rsync实战操作

前面介绍了一些关于rsync的功能与一些具体的命令格式、参数的使用意义等,今天我们来聊一聊整个实际生产过程中的实战操作过程

今天介绍的是第三种模式——以守护进程的模式传输数据

一:整体环境

备份服务器端(BK-S)

[root@BS-S~]# cat /etc/redhat-release
CentOS release 6.5 (Final)
[root@BS-S ~]# uname -r
2.6.32-431.el6.x86_64

备份数据的客户端(BK-C)

[root@BS-C ~]# cat /etc/redhat-release
CentOS release 6.5 (Final)
[root@BS-C ~]# uname -r
2.6.32-431.el6.x86_64

二:配置过程

以下配置为备份数据服务器端

1、检查是否安装软件

[root@BK-S ~]# rpm -qa |grep "rsync"
rsync-3.0.6-9.el6_4.1.x86_64

2、配置rsync的配置文件/etc/rsync.conf

[root@BK-S ~]#cat /etc/rsyncd.conf  
cat:/etc/rsyncd.conf: No such file or directory

显示系统无此文件,因此我们直接创建文件

[root@BK-S ~]# vi /etc/rsyncd.conf 
##rsync config  start                         

##created by root 2016-08-08 15:00
##rsyncd.conf config start    以上为注释部分
uid = rsync
gid = rsync
use chroot = no
max connetctions = 200  最大连接数(并发)
timeout = 100  超时时间默认S单位
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log
[backup]                            模块名称可自定义任意名称
path = /backup/                 备份数据的路径
ignore errors                    忽略错误
read only = false
list = false
hosts allow = 192.168.1.0/24
hosts deny = 0.0.0.0/32
auth users = rsync_backup 虚拟的用户用于连接认证
secrets file = /etc/rsync.password  认证的密码配置文件路径
##rsync config  end

整个配置过程中注意中间的空格与书写规范

检查配置文件

[root@BK-S ~]# cat /etc/rsyncd.conf 
##rsync config  start
##created by root 2016-08-08 15:00
##rsync.conf config start
uid = rsync
gid = rsync
use chroot = no
max connetctions = 200
timeout = 100
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log
[backup]
path = /backup/
ignore errors
read only = false
list = false
hosts allow = 192.168.1.0/24
hosts deny = 0.0.0.0/32
auth users = rsync_backup
secrets file = /etc/rsync.password
##rsync config  end

3、格式化配置文件

[root@BK-S ~]#dos2unix /etc/rsync.conf            没有安装
-bash: dos2unix:command not found
[root@BK-S ~]#yum install dos2unix -y YUM进行安装
Loaded plugins:fastestmirror, refresh-packagekit, security
Loading mirrorspeeds from cached hostfile
 * base: mirrors.zju.edu.cn
 * extras: mirrors.zju.edu.cn
 * updates: mirrors.zju.edu.cn
base                                              | 3.7 kB     00:00    
extras                                             |3.4 kB     00:00    
updates                                            |3.4 kB     00:00   
updates/primary_db                                 | 2.0 MB     00:01    
Setting up InstallProcess
ResolvingDependencies
--> Runningtransaction check
---> Packagedos2unix.x86_64 0:3.1-37.el6 will be installed
--> FinishedDependency Resolution
DependenciesResolved
============================================
 Package          Arch           Version               Repository    Size
======================================Installing:
 dos2unix         x86_64         3.1-37.el6            base          16 k
TransactionSummary
============================================
Install       1 Package(s)
Total downloadsize: 16 k
Installed size: 18k
DownloadingPackages:
dos2unix-3.1-37.el6.x86_64.rpm          |  16kB     00:00    
Running rpm_check_debug
RunningTransaction Test
Transaction TestSucceeded
RunningTransaction
  Installing : dos2unix-3.1-37.el6.x86_64               1/1
  Verifying : dos2unix-3.1-37.el6.x86_64                1/1
Installed:
  dos2unix.x86_64 0:3.1-37.el6                                
Complete!
[root@BK-C]#dos2unix /etc/rsync.conf
dos2unix:converting file /etc/rsync.conf to UNIX format ...

4、添加用户

[root@BK-S ~]#useradd rsync -s /sbin/nologin -M
[root@BK-S /]#mkdir backup
[root@BK-S /]#chown -R rsync.rsync /backup          
[root@BK-S /]# ls -ll
drwxr-xr-x.   2 rsync rsync   4096 Aug 27 14:30 backup
dr-xr-xr-x.   2 root  root    4096 Aug 15 19:15 bin
dr-xr-xr-x.   5 root  root    1024 Aug  7 18:04 boot
drwxr-xr-x.   3 root  root    4096 Aug 21 10:07 data
drwxr-xr-x.  19 root  root    3860 Sep  2 05:05 dev

5、配置密码文件

[root@BK-S /]# echo "rsync_backup:rsync.conf">>/etc/rsync.password
[root@BK-S /]# cat /etc/rsync.password                           
rsync_backup:rsync.conf              认证用户:认证密码
因密码文件为明文,所以需要改变默认权限
[root@BK-S /]# chmod 600  /etc/rsync.password
[root@BK-S /]# ls -ld /etc/rsync.password
-rw-------. 1 root root 24 Sep  2 05:43 /etc/rsync.password

6、启动服务

[root@BK-S /]# rsync --daemon                   启动服务后台运行
[root@BK-S /]# netstat -lntup |grep rsync    查看服务使用端口
tcp  0   0 0.0.0.0:873     0.0.0.0:*    LISTEN    2013/rsync     
tcp  0   0 :::873             :::*              LISTEN    2013/rsync  
[root@BK-S /]# ps -ef |grep rsync
root      2013      1  0 05:45 ?        00:00:00 rsync --daemon
root      2018   1930  0 05:46 pts/0    00:00:00 grep rsync

至此备份数据的服务端配置结束

7、以下为客户配置过程

[root@BK-C ~]# echo "rsync.conf">/etc/rsync.password 
[root@BK-C ~]# cat /etc/rsync.password              
rsync.conf
[root@BK-C ~]# chmod 600 /etc/rsync.password
[root@BK-C ~]# ls -ld /etc/rsync.password
-rw-------. 1 root root 11 Sep  3 13:57 /etc/rsync.password

客户端配置结束

三:测试数据备份

[root@BK-C ~]# rsync -avzP /etc/hosts rsync_backup@192.168.1.2::backup --password-file=/etc/rsync.password
rsync: failed to connect to 192.168.1.2: No route to host (113)
rsync error: error in socket IO (code 10) at clientserver.c(124) [sender=3.0.6]

报错提示没有路由,表明服务端防火墙没有关闭

[root@BK-S backup]# /etc/init.d/iptables stop
iptables: Setting chains to policy ACCEPT: filter [  OK  ]
iptables: Flushing firewall rules:                          [  OK  ]
iptables: Unloading modules:                              [  OK  ]

服务端关闭防火墙

[root@BK-C~]# rsync -avzP /etc/hosts rsync_backup@192.168.1.2::backup --password-file=/etc/rsync.password
sending incremental file list
hosts
         322 100%    0.00kB/s    0:00:00 (xfer#1, to-check=0/1)
sent 141 bytes  received 27 bytes  336.00 bytes/sec

total size is 322  speedup is 1.92

显示数据备份完成

备份服务器上查看是否备份成功

[root@BK-C~]# cat /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
###########www.baidu.com################
###########www.baidu.com################
###########www.baidu.com################
###########www.baidu.com################
[root@BK-S backup]# ls -ll
total 4
-rw-r--r--. 1 rsync rsync 322 Aug 30 03:29 hosts
[root@BK-S backup]# cat hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
###########www.baidu.com################
###########www.baidu.com################
###########www.baidu.com################
###########www.baidu.com################

两台服务器上hosts文件内容相同,表明备份成功

[root@BK-C ~]# cd /tmp
[root@BK-C tmp]# ls
[root@BK-C tmp]# ls -ll
total 0
[root@BK-C tmp]# touch 123.txt
[root@BK-C tmp]# touch 321.txt
[root@BK-C tmp]# rsync -avzP /tmp/ rsync_backup@192.168.1.2::backup --
password-file=/etc/rsync.password         
sending incremental file list
./
123.txt
           0 100%    0.00kB/s    0:00:00 (xfer#1, to-check=2/4)
321.txt
           0 100%    0.00kB/s    0:00:00 (xfer#2, to-check=1/4)
.ICE-unix/
sent 162 bytes  received 53 bytes  430.00 bytes/sec

total size is 0  speedup is 0.00

服务端查看数据同步情况

[root@BK-S backup]# ls -ll
total 4
-rw-r--r--. 1 rsync rsync   0 Sep  9  2016 123.txt
-rw-r--r--. 1 rsync rsync   0 Sep  9  2016 321.txt
-rw-r--r--. 1 rsync rsync 322 Aug 30 03:29 hosts

测试--delete参数

[root@BK-S backup]# mkdir text
[root@BK-S backup]# mkdir text1
[root@BK-S backup]# mkdir text2
[root@BK-S backup]# mkdir text3
[root@BK-S backup]# touch 4565.bak
[root@BK-S backup]# touch 4565.txt
[root@BK-S backup]# ls -ll
total 20
-rw-r--r--. 1 rsync rsync    0 Sep  9  2016 123.txt
-rw-r--r--. 1 rsync rsync    0 Sep  9  2016 321.txt
-rw-r--r--. 1 root  root     0 Sep  7 13:48 4565.bak
-rw-r--r--. 1 root  root     0 Sep  7 13:48 4565.txt
-rw-r--r--. 1 rsync rsync  322 Aug 30 03:29 hosts
drwxr-xr-x. 2 root  root  4096 Sep  7 13:48 text
drwxr-xr-x. 2 root  root  4096 Sep  7 13:48 text1
drwxr-xr-x. 2 root  root  4096 Sep  7 13:48 text2
drwxr-xr-x. 2 root  root  4096 Sep  7 13:48 text3
[root@BK-C tmp]# rsync -avzP --delete /tmp/ rsync_backup@192.168.1.2::
backup --password-file=/etc/rsync.password
sending incremental file list
./
deleting text3/
deleting text2/
deleting text1/
deleting text/
deleting hosts
deleting 4565.txt
deleting 4565.bak
sent 91 bytes  received 12 bytes  206.00 bytes/sec

total size is 0  speedup is 0.00

服务器端查看结果

[root@BK-S backup]# ls -ll
total 0
-rw-r--r--. 1 rsync rsync 0 Sep  9  2016 123.txt
-rw-r--r--. 1 rsync rsync 0 Sep  9  2016 321.txt

最终结果显示delete参数的作用就是:客户端有什么,远端服务器就有什么,客户备份目录下没有的,远端服务器目录下其它文件或目录就会被删除,此参数相当危险,实际生产环境中要小心使用