一、Rsync的简单介绍

Rsync是一款开源的、快速的、多功能的、可实现全量及增量(全量备份是指全部备份,增量备份是在上一次备份的基础上只备份更新的内容)的本地货远程数据同步备份的优秀工具。Rsync软件适用于unix/linux/windows等多种操作系统平台。

二、Rsync的三种工作模式

#rsync 本地模式

Local:  rsync [OPTION...] SRC... [DEST]

#rsync shell模式

Access via remote shell:

  Pull: rsync [OPTION...] [USER@]HOST:SRC... [DEST]

  Push: rsync [OPTION...] SRC... [USER@]HOST:DEST

#rsync daemon模式

Access via rsync daemon:

  Pull: rsync [OPTION...] [USER@]HOST::SRC... [DEST]

        rsync [OPTION...] rsync://[USER@]HOST[:PORT]/SRC... [DEST]

  Push: rsync [OPTION...] SRC... [USER@]HOST::DEST

        rsync [OPTION...] SRC... rsync://[USER@]HOST[:PORT]/DEST

三、Rsync常用参数

-v

详细模式输出,传输时的进度等信息

-z

传输时进行压缩以提高传输效率,--compress-level=NUM可按级别压缩

-a

以递归方式传输文件,并保持所有文件的属性

-r

对子目录以递归模式,即目录下的所有目录都以同样的模式传输

-t

保持文件的时间信息

-o

保持文件的属主信息

-p

保持文件的权限

-g

保持文件的属组信息

-P(大写)

显示同步的过程及传输时的进度等信息

-D

保持设备文件信息

-I

保留软链接

-e,--rsh=COMMAND

使用的信道协议,指定替代rsh的shell程序

-n

测试选项,模拟执行

--exclude=PATTERN

指定排除不需要传输的文件模式

--exclide-from=FILE

从文本文件读取需要排除的文件列表

--bwlimit=KBPS

限制传输速度

--partial

断点续传

--delete

使目标目录内容和源保持目录一致,删除不同的文件

四、搭建Rsync服务

实验环境:

<1>系统环境:

•CentOS7.5

<2>主机环境:

•backup01  IP地址:10.0.0.41  rsync服务端(备份服务端)

•nfs01    IP地址:10.0.0.31  rsync客户端(用户数据)

1、服务端(远程备份服务器)

第一步:查看rsync安装包
rpm -qa rsync 第二步:添加rsync服务的用户,管理本地目录
useradd -s /sbin/nologin -M rsync
id rsync 第三步:配置rsync的进程模式(vim /etc/rsyncd.conf)
uid = rsync
gid = rsync
use chroot = no
max connections =
timeout =
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
fake super = yes
hosts allow = 172.16.2.0/
hosts deny = 0.0.0.0/
auth users = rsync_backup
secrets file = /etc/rsync.password 第四步:根据rsync.conf的auth_users配置帐户,远程连接的,并根据secreets file参数生成密码文件
echo "rsync_backup:wt">>/etc/rsync.password
cat /etc/rsync.password 第五步:更改密码配置文件的权限
chmod /etc/rsync.password
ls -l /etc/rsync.password 第六步:创建共享的目录授权rsync服务管理
mkdir -p /backup
chown -R rsync.rsync /backup #提示:如果没有/backup目录,就会chdir failed 第七步:启动rsync服务并检查
rsync --daemon
ps -ef|grep rsync|grep -v grep
lsof -i : 第八步:开机自启动
echo "/usr/bin/rsync --daemon">>/etc/rc.local
tail - /etc/rc.local

2、客户端

第一步:生成连接服务器需要的密码文件
echo "wt">>/etc/rsync.password
cat /etc/rsync.password 第二步:为密码文件配置权限
chmod /etc/rsync.password
ls -l /etc/rsync.password

3、客户端推送数据到服务端

提示:rsync: chgrp "data" (in backup) failed: Operation not permitted (1),出现这个语句是因为rsyncd.conf没有配置fake super = yes

[root@nfs01 ~]# mkdir /data
[root@nfs01 ~]# cd /data/
[root@nfs01 data]# touch aaa
[root@nfs01 data]# rsync -avz /data rsync_backup@172.16.2.41::backup/
Password:
sending incremental file list
rsync: chgrp "data" (in backup) failed: Operation not permitted ()
data/
data/aaa
rsync: chgrp "data/.aaa.3HdDEQ" (in backup) failed: Operation not permitted () sent bytes received bytes 37.76 bytes/sec
total size is speedup is 0.00
rsync error: some files/attrs were not transferred (see previous errors) (code ) at main.c() [sender=3.1.]

4、服务端查看数据是否推送成功

[root@backup01 ~]# cd /backup/
[root@backup01 backup]# ls
data
[root@backup01 backup]# cd
[root@backup01 ~]# cd /backup
[root@backup01 backup]# ls
data
[root@backup01 backup]# ls data/
aaa

五、Rsync多模块配置

uid = rsync
gid = rsync
use chroot = no
max connections =
timeout =
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
fake super = yes
hosts allow = 172.16.2.0/
hosts deny = 0.0.0.0/
auth users = rsync_backup
secrets file = /etc/rsync.password [wtt]
path = /wtt
ignore errors
read only = false
list = false
fake super = yes
hosts allow = 172.16.2.0/
hosts deny = 0.0.0.0/
auth users = rsync_wtt
secrets file = /etc/rsync.password.wtt

六、深入使用Rsync

1、从远程存储节点拉取数据到本地

[root@nfs01 ~]# cd /data/
[root@nfs01 data]# ls
aaa ssss
[root@nfs01 data]# rm -f *
[root@nfs01 data]# rsync -avz rsync_backup@172.16.2.41::backup/ /data/ --password-file=/etc/rsync.password
receiving incremental file list
./
aaa
ssss sent bytes received bytes 500.00 bytes/sec
total size is speedup is 0.00

2、排除某些文件推送数据

#同步除名为eee文件之外的文件

[root@nfs01 data]# ls

aaa  bbb  ccc  ddd  eee  ssss

[root@nfs01 data]# rsync -avz --exclude=eee /data rsync_backup@172.16.2.41::backup/ --password-file=/etc/rsync.password

sending incremental file list

data/

data/aaa

data/bbb

data/ccc

data/ddd

data/ssss

sent  bytes  received  bytes  922.00 bytes/sec

total size is   speedup is 0.00

#查看远程存储节点的数据内容

[root@backup01 backup]# ls

data

[root@backup01 backup]# ls data/

aaa  bbb  ccc  ddd  ssss

3、排除多个文件推送数据

#同步除名为ccc和eee文件之外的文件

[root@nfs01 data]# ls

aaa  bbb  ccc  ddd  eee  ssss

[root@nfs01 data]# rsync -avz --exclude={ccc,eee} /data rsync_backup@172.16.2.41::backup/ --password-file=/etc/rsync.password

sending incremental file list

data/

data/aaa

data/bbb

data/ddd

data/ssss

sent  bytes  received  bytes  784.00 bytes/sec

total size is   speedup is 0.00

#查看远程存储节点的数据内容

[root@backup01 backup]# ls

data

[root@backup01 backup]# ls data/

aaa  bbb  ddd  ssss

8.4、排除连续文件推送数据

[root@nfs01 data]# ls

a  aaa  b  bbb  c  ccc  ddd  eee  ssss

[root@nfs01 data]# rsync -avz --exclude={a..c} /data rsync_backup@172.16.2.41::backup/ --password-file=/etc/rsync.password

sending incremental file list

data/

data/aaa

data/bbb

data/ccc

data/ddd

data/eee

data/ssss

sent  bytes  received  bytes  356.67 bytes/sec

total size is   speedup is 0.00

5、通过排除文件推送数据

[root@nfs01 data]# cat /tmp/file.txt

ssss

eee

g

[root@nfs01 data]# ls

a  aaa  b  bbb  c  ccc  ddd  eee  ssss

[root@nfs01 data]# rsync -avz --exclude-from=/tmp/file.txt /data rsync_backup@172.16.2.41::backup/ --password-file=/etc/rsync.password

sending incremental file list

data/

data/a

data/aaa

data/b

data/bbb

data/c

data/ccc

data/ddd

sent  bytes  received  bytes  402.67 bytes/sec

total size is   speedup is 0.00

6、无差异同步(--delete)

注意:使用—delete选项,即本地有啥,远程存储节点就业啥,如果远程存储节点有别的数据。那么这些“别的数据”将全部被删除掉,所有慎用这个--delete选项。

#远端存储节点的数据如下

[root@backup01 backup]# ls

data

[root@backup01 backup]# ls data/

a  aaa  b  bbb  c  ccc  ddd

#本地数据如下

[root@nfs01 data]# ls

a  b  c  d  e  f  g

#本地数据推送到远程存储服务器

[root@nfs01 data]# rsync -avz --delete  /data rsync_backup@172.16.2.41::backup/ --password-file=/etc/rsync.password

sending incremental file list

deleting data/ddd

deleting data/ccc

deleting data/bbb

deleting data/aaa

data/

data/a

data/b

data/c

data/d

data/e

data/f

data/g

sent  bytes  received  bytes  ,254.00 bytes/sec

total size is   speedup is 0.00

#再次查看远程存储服务器的备份数据内容发现 {aaa bbb ccc}这三个文件被删除了

[root@backup01 backup]# ls

data

[root@backup01 backup]# ls data/

a  b  c  d  e  f  g

8.7  限制速度推送数据(--bwlimit=KBPS)

#未限速

[root@nfs01 data]# dd if=/dev/zero of=test1 bs=1M count=

[root@nfs01 data]# rsync -avz   /data rsync_backup@172.16.2.41::backup/ --password-file=/etc/rsync.password

sending incremental file list

data/

data/test1

sent , bytes  received  bytes  ,783.09 bytes/sec

total size is ,,  speedup is ,026.07

#限速

[root@nfs01 data]# rsync -avz --bwlimit=10k  /data rsync_backup@172.16.2.41::backup/ --password-file=/etc/rsync.password

sending incremental file list

data/

data/test1

sent , bytes  received  bytes  ,689.41 bytes/sec

total size is ,,  speedup is ,026.07

Linux搭建rsync服务的更多相关文章

  1. [Linux] 搭建rsync服务端

    rsync是unix/linux下同步文件的一个高效算法,它能同步更新两处计算机的文件与目录,并适当利用查找文件中的不同块以减少数据传输. Linux守护进程的运行方式:1.独立运行(stand-al ...

  2. Centos6.9 搭建rsync服务端与客户端 案例:全网备份项目

    rsync的企业工作场景说明 1)定时备份 1.1生产场景集群架构服务器备份方案项目 借助cron+rsync把所有客户服务器数据同步到备份服务器 2)实时复制 本地数据传输模式(local-only ...

  3. 最全Linux搭建SVN服务端教程

    文章首推 支付宝接口对接 高德地图调用 验证码登录 QQ邮箱登录 今日主题:Linux搭建SVN服务端 简介 相信程序员对SVN还是不陌生的,虽然现在用Git比较多,但是SVN也是用的,SVN可以做代 ...

  4. linux 搭建SVN服务端

    搞了个服务器,然后现在想搞点事情,于是乎整个SVN在上面,算是熟悉下svn的操作过程 以下内容转载自: https://yq.aliyun.com/articles/6693 ------------ ...

  5. Linux搭建NFS服务

    一.NFS服务简单介绍 NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源.在NFS的应用中, ...

  6. Linux搭建rsync备份服务器备份

    环境: 1台rsync备份服务器,IP:10.0.0.188 1台rsync备份客户端,IP:10.0.0.51 备份数据需注意: 1. 在业务低谷时间进行备份 2. 进行备份限速 一.搭建rsync ...

  7. 搭建rsync服务(端口号873)

    rsync详细参数 1.-v,--verbose 详细模式输出,传输是的进度信息 2.-z,--compress 传输是进行压缩以提高传输效率,--comperess -level = NUM可以按级 ...

  8. linux搭建apache服务并修改默认路径

    该篇文章主要讲解如何在linux服务器上搭建apache服务器,并修改指定的apache路径到自定义路径下 一:检查服务器上是否已安装apache,停止并卸载系统自带apache服务 命令为:rpm ...

  9. Linux——搭建FTP服务

    一.FTP基本概念: 1.FTP的作用: 实现文件系统的安全匿名访问:包括上传.下载和查看,可以应用于Windows和Linux系统 2.FTP的工作原理 server与client都支持ftp传输协 ...

随机推荐

  1. Java基础知识总结之多线程

    1.基本概念 进程是程序的一次动态执行过程,是系统进行资源分配和调度运行的基本单位. 线程是进程的一个实体,它是比进程更小的的能够独立运行的基本单位.在引入线程的操作系统中,通常都是把进程作为分配资源 ...

  2. Siamese-RPN论文阅读

    https://www.cnblogs.com/zhengyuqian/p/10609737.html

  3. 用Helm3构建多层微服务

    Helm是一款非常流行的k8s包管理工具.以前就一直想用它,但看到它产生的文件比k8s要复杂许多,就一直犹豫,不知道它的好处能不能抵消掉它的复杂度.但如果不用,而是用Kubectl来进行调式真的很麻烦 ...

  4. yum运行报错:File "/usr/bin/yum", line 30 except KeyboardInterrupt, e: ^SyntaxError: invalid syntax

    这是由于Python升级导致 备份Python 历史版本 [root@sdw1 autoconf]# ls /usr/bin/python* [root@sdw1 autoconf]# mv /usr ...

  5. SQL Server2017 安装完成后找不到启动项解决方案

    很多用于当SQL Server2017 安装完成后开始菜单找不到启动项无法启动SQL Server2017 其实你只需要安装一下SSMS-Setup-CHS就可以了 安装完成之后就有了 SSMS-Se ...

  6. 关于for循环中使用setTimeout

    我们先来简单了解一下setTimeout延时器的运行机制.setTimeout会先将回调函数放到等待队列中,等待区域内其他主程序执行完毕后,按时间顺序先进先出执行回调函数.本质上是作用域的问题. 因此 ...

  7. CCNA 之 九 STP生成树协议

    STP生成树 在上一次实验中,使用了单臂路由是两个不同的VLAN之间进行通信,而单臂路由的这种网络拓扑,当一条链路或者路由设备出现故障的时候,整个网络就会瘫痪. 称此网络为:不健壮的,无冗余的网络环境 ...

  8. c堆排序

    #include<stdio.h> #include<stdlib.h> /* p是循环输出的下表*/ ; /*堆调整算法*/ /* r[]数组 , 根结点的编号为k,最后一个 ...

  9. 机器学习十大算法总览(含Python3.X和R语言代码)

    引言 一监督学习 二无监督学习 三强化学习 四通用机器学习算法列表 线性回归Linear Regression 逻辑回归Logistic Regression 决策树Decision Tree 支持向 ...

  10. appium自动化的一个实例

    实现appium的自动化,三步走,具体如下: 第一步:启动appium的服务端: 可以通过命令行的方式启动:cmd,然后输入appium,如下图 也可以打开桌面程序appium,点击右上角的运行按钮, ...