yum install rsync -y

rsync(873):数据同步,把一台服务器上的数据以何种权限同步到另一台服务器上,是linux

系统下的数据镜像备份工具。使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,

或者与其他SSH;sync主机同步可以全量和增量的本地或远程数据同步;rsync守护进程(daemon)的方式传输数据,监听的是rsync 837的端口;

3.1、rsync的特性:

3.2、rsync的拷贝:

3.3、解决ssh传输慢的问题:

在远程服务器上进行/etc/ssh/sshd_config的设置:

3.4、rsync,local模式:

rsync -avz /etc/hosts /tmp/ :普通备份(源目录和目标目录进行对比,内容相同的部分不拷贝到目标目录。

内容不同的部分拷贝到目标目录,目标目录存在而源目录不存在的内容会被保留。目标目录的内容是源目录和原目标目录内容的并集(更新)。

类似于\cp -av /etc/hosts /tmp:将源目录数据拷贝到目标目录,内容名称相同覆盖,不相同的复制。目标目录和源目录内容名称不同的

保留(更新)。)

rsync -avz --delete /tmp/ /mnt/ :同步备份(源目录和目标目录进行对比,内容相同的部分不拷贝到目标目录,内容不同的部分拷

贝到目标目录。目标目录存在而源目录不存在的内容不会被保留。目标目录和源目录内容持一致(同步)。)

特别提示:

源目录和目标目录内容进行对比的方法有:通过文件或目录的名称、修改时间、大小来判断是不是同一个内容。

3.5、rsyncssh远程模式:

rsync -avz /etc -e 'ssh -p 22' root@172.16.1.31:/tmp #也可以使用--delete:用法和本地local传输相同

3.6、daemon模式:

3.6.1、rsync参数配置:

修改/etc/rsyncd.conf配置文件:

uid = rsync #同步文件的属主 使用rsync用户访问共享目录

gid = rsync #同步文件的属组

use chroot = no #安全相关的设置,一般不使用chroot

max connections = 200 #最大连接数

timout=300 #超时参数(单位/秒)

pid file = /var/run/rsyncd.pid #进程号对应的文件

lock file = /var/run/rsync.lock #锁文件,防止文件不一致

log file = /var/log/rsyncd.log #日志文件

[backup] #这里是认证的模块名,在client端需要指定

path = /backup #服务器提供的共享目录

comment = backup #描述信息

ignore errors #可以忽略一些无关的IO错误

read only = false #可写

list = false #不允许列文件 相当于ls

hosts allow=172.16.1.0/24 #允许的网段

#hosts deny=0.0.0.0/32 #拒绝的网段

auth users = rsync_backup #连接的系统中不存在的虚拟用户,对应的是uid中用户,这样同步的时候比较安全

secrets file = /etc/rsync.password #虚拟用户的用户和密码文件

3.6.2、在系统中添加虚拟用户:

useradd rsync -Ms /sbin/nologin

[root@backup /]# tail -1 /etc/passwd

rsync:x:501:501::/home/rsync:/sbin/nologin

3.6.3、创建共享目录:

mkdir -p /backup

chown -R rsync:rsync /backup/

[root@backup /]# ls -ld /backup/

drwxr-xr-x 2 rsync rsync 4096 10月 7 17:12 /backup/

3.6.4、创建密码文件:

[root@backup /]# touch /etc/rsync.password

[root@backup /]# chmod 700 /etc/rsync.password

[root@backup /]# ls -l /etc/rsync.password

-rwx------ 1 root root 0 10月 7 17:22 /etc/rsync.password

[root@backup /]# vim /etc/rsync.password

rsync_backup:123

3.6.5、启动rsync服务:

(rsync服务在root用户下运行,只是对同步文件的权限做了更改)

3.6.5.1、加入开机自启动:

echo ‘/usr/bin/rsync --daemon’>>/etc/rc.local

tail -1 /etc/rc.local

rsync --daemon

ps -ef |grep "rsync" |grep -v "rsync"

root 2363 1 0 17:05 ? 00:00:00 rsync --daemon

3.6.5.2、修改了 /etc/rsyncd.conf配置文件中的内容后要重启:

pkill rsync #杀死了rsync进程

lsof -i :873 #产看进程是否被杀死

rsync --daemon#启动rsync服务

lsof -i :873

3.6.6、客户端配置:

mkdir /etc/rsync.password

touch '123' >>/etc/rsync.password

chmod 700 /etc/rsync.password

[root@nfs01 ~]# ls -l /etc/rsync.password

-rwx------ 1 root root 4 10月 7 17:54 /etc/rsync.password

3.6.7、rsync参数补充:

--delete:无差异同步,服务端 和客户端保持一致,谨慎使用该参数

举例:视频网站,视频推送到服务器上发布,本地/backup只有当天发布的内容,服务器上有以前的所有文件,使用--delete参数进行数据同步

时会删除服务器duan以前的所有内容,只有当天发布的内容了 。

--exclude:排除文件

--exclude=a:单个排除

--exclude={a,b,c}:多个排除

--exclude={a..b}:连续排除

--bwlimit=KBPS:限速

--bwlimit=10(kB/s)

-P:断点续传

-avzP

3.6.7.1、push同步(客户端-服务端):

服务端中配置的模块名,对应的是服务端的共享地址,也可以在后面加目录,比如backup/a/,这a目录可以不存在,会自动创建;

rsync -avz /backup rsync_backup@172.16.1.41::backup/ --password-file=/etc/rsync.password

rsync -avz --bwlimit=20 /backup rsync_backup@172.16.1.41::backup/ --password-file=/etc/rsync.password

3.6.7.2、pull同步(服务端-客户端)

服务端中配置的模块名,对应的是服务端的共享地址,也可以在后面加目录,比如backup/a,backup/a表示拉整个目录,backup/a/表示拉目录中的内容,a目录必须存在,且权限和上层目录一致;

rsync -avz rsync_backup@172.16.1.41::backup/ /backup/ --password-file=/etc/rsync.password

rsync -avz --exclude={a,lc3.pdf,lc4.pdf} rsync_backup@172.16.1.41::backup/ /backup/ --password-file=/etc/rsync.password

3.7、错误解析:

3.7.1、@error:invalid uid rsync

用户不存在,需要创建用户 useradd -Ms rsync

3.7.2、@error: auth failed on module backup

rsync服务器端 /etc/rsync.password配置文件用户密码和/etc/rsyncd.conf配置文中的非系统内虚拟账号不一致,或者是客户端密码文件错误

3.7.3、@error:chdir faild

rsync服务器端共享目录权限不够

3.8、多模块设置:

vim /etc/rsyncd.conf

uid = rsync

gid = rsync

use chroot = no

max connections = 200

timout=300

pid file = /var/run/rsyncd.pid

lock file = /var/run/rsync.lock

log file = /var/log/rsyncd.log

ignore errors

read only = false

list = false

hosts allow = 172.16.1.0/24

#hosts deny = 0.0.0.0/32

auth users = rsync_backup

secrets file = /etc/rsync.password

[backup]

path = /backup

comment = backup

[backup2]

path = /backup2

comment = backup2

此种多模块配置设置的是一个独立于系统之外的虚拟用户对应不同的模块,其余的配置都放在了公共的部分,如果有需要可以从公共

的部分拿出来进行单独的配置,设置不同的独立于系统之外的虚拟账号,需要在/etc/rsync.password配置文件中添加相应的用户和密码即可。

3.9、总结:

3.9.1、rsync共有三种模式:

local模式

ssh通道模式(ssh会自动加密)

daemon模式

内网不需要加密,加密数据会有损失

rsync+vpn(pptp(简单易懂),openvpn,ipsec)

3.9.2、rsync的优缺点:

优点:

增量备份和无差异备份(对比文件,相同的文件不备份,速度快),支持socket(daemon),集中备份(支持推拉,都是以客户端为参照物);

远程ssh通道模式还可以加密(ssh)传输,socket(daemon)需要假币传输,可以利用vpn服务或是ipsec服务;

缺点:

大量小文件同步的时候,比对时间较长,有时候,rsync进程可能会停止;

同步大文件,10G这样的大文件时也会有这样的问题,会中断,未完整同步前,是隐藏文件,可以通过续传实现传输;

一次性远程拷贝可以使用scp;

3、搭建 rsync备份服务器的更多相关文章

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

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

  2. Linux中架构中的备份服务器搭建(rsync)

    本期内容概要 Linux中的备份方式 架构中备份服务器搭建(rsync) 内容详细 1.备份方式 1. cp : 本机复制(只能作用在本机) 2. scp : 远程复制 两种模式: 推 : 本地上传到 ...

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

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

  4. Linux搭建rsync服务

    一.Rsync的简单介绍 Rsync是一款开源的.快速的.多功能的.可实现全量及增量(全量备份是指全部备份,增量备份是在上一次备份的基础上只备份更新的内容)的本地货远程数据同步备份的优秀工具.Rsyn ...

  5. 搭建rsync+inotify实现实时备份

    一.环境搭建说明 系统环境 CentOS7.5 备份节点 主机名:backup01 IP地址:172.16.2.41 数据节点 主机名:nfs-master IP地址:172.16.2.31 二.在备 ...

  6. CentOS7.5搭建Rsync,实现文件同步

    Rsync(remote sync)是UNIX及类UNIX平台下一款神奇的数据镜像备份软件,它不像FTP或其他文件传输服务那样需要进行全备份,Rsync可以根据数据的变化进行差异备份,从而减少数据流量 ...

  7. Linux如何从零开始搭建rsync+serync服务器(centOS6)

    一.为什么要用Rsync+sersync架构? 1.sersync是基于Inotify开发的,类似于Inotify-tools的工具 2.sersync可以记录下被监听目录中发生变化的(包括增加.删除 ...

  8. Linux下如何使用Rsync备份服务器重要数据

    Rsync介绍: Rsync英文全称Remote synchronization,从软件的名称就可以看出来,Rsync具有可使本地和远程两台主机之间的数据快速复制同步镜像,远程备份的功能,这个功能类似 ...

  9. [Linux] 搭建rsync服务端

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

随机推荐

  1. [bug] Navicat 连 虚拟机MySQL

    参考 https://www.cnblogs.com/brankoliu/p/10845491.html https://blog.csdn.net/qq_40087740/article/detai ...

  2. [Java] Spring 使用

    背景 JavaEE 应用框架 基于IOC和AOP的结构J2EE系统的框架 IOC(反转控制):即创建对象由以前的程序员自己new 构造方法来调用,变成了交由Spring创建对象,是Spring的基础 ...

  3. 061.Python前端Django组件用户认证组件

    一 auth认证组件 在使用pymysql,数据库迁移的时候.,默认生成有十张表如下 查看author_user表结构 mysql> desc auth_user; +------------- ...

  4. linux基础之用户及用户组管理

    本节内容 用户管理 1. 为什么需要用户? 1.linux是一个多用户系统 2.权限管理(权限最小化) 2. 用户相关文件 /etc/passwd -->用户基本信息 /etc/shadow - ...

  5. origin2018去掉demo水印

    消除demo字样 有的origin破解完成后,使用没问题,但导出的图有demo水印.其实不需要重装,只需要下载一个补丁即可解决. 1. 把下载到的origin.exe复制到安装文件夹 2. 双击执行一 ...

  6. 3d分层悬停效果

    3d分层悬停效果 写在前面 经过了2个星期的努力,我回来了!会继续将我学习路上遇到的问题,以及一些笔记,demo分享给大家 实现效果 致我最爱的backpink 实现思路 将6张图片,通过定位叠在一起 ...

  7. VMware Tanzu Kubernetes Grid 1.3 发布 - VMware 构建、签名和支持的开源 Kubernetes 容器编排平台的完整分发版

    Tanzu Kubernetes 集群是由 VMware 构建.签名和支持的开源 Kubernetes 容器编排平台的完整分发版.可以通过使用 Tanzu Kubernetes Grid 服务在主管集 ...

  8. 行者APP适配国外环境问题解决

    (本文1151字,阅读约5分钟) 玩骑行的同伴都知道,长途骑行,第一需要好的硬件,如大腿发动机.车子.装备等:二是需要好的软件,如意志.有氧能力.骑行app等. 到雅加达后,才发现在国内用了几年的黑鸟 ...

  9. .Net Redis实战——事务和数据持久化

    Redis事务 Redis事务可以让一个客户端在不被其他客户端打断的情况下执行多个命令,和关系数据库那种可以在执行的过程中进行回滚(rollback)的事务不同,在Redis里面,被MULTI命令和E ...

  10. 第三方跨平台进程和系统监控库gopsutil

    gopsutil psutil是一个跨平台进程和系统监控的Python库,而gopsutil是其Go语言版本的实现.本文介绍了它的基本使用. Go语言部署简单.性能好的特点非常适合做一些诸如采集系统信 ...