美文网首页
第三十二天 rsync 远程连接

第三十二天 rsync 远程连接

作者: 杨小倪 | 来源:发表于2019-09-26 15:48 被阅读0次

RSYNC远程同步

1.什么是备份

给源文件准备一个副本,就是备份

2.为什么要做备份?

1)数据重要

2)防止误操作

3)能够快速恢复

3.能不能不做备份?

可以,不重要的数据可以不用考虑备份;

对于重要的数据,我们还是习惯做好备份,安全

4.备份使用什么方式?

全量备份:每次备份都是完全拷贝,效率

增量备份:每次仅拷贝发生变化的文件,效率较高

5.备份使用的工具有哪些?

本地备份:cp

远程备份: scp rsync sz rz

6.rsync 远程同步工具

实现主机与主机之间的同步,实现增量同步 适用于:linux/Windows/mac

PS:如果将rsync当成一个服务来使用,则需要知道 rsync 是个 C/S架构

PS:C/S架构,即Client-Service模式(客户机-服务器)

7.rsync 推 和 拉 两种方式

推: 上传到服务器

拉:从服务器下载到本地

推和拉的结合使用

8.rsync的传输模式

1)本地传输 ---> 类似于 cp

#等价于cp命令
Local:  rsync [OPTION...] SRC... [DEST]
        命令   选项      源      目标

[root@backup ~]# rsync -avz anaconda-ks.cfg  /tmp/

2)远程传输 ---> 类似于scp

远程传输
Access via remote shell:
上传    Push: rsync [OPTION...] SRC...[USER@]HOST:DEST
            命令   选项         源   系统用户 主机IP 目标位置
        1.我要将我本地的那个文件,推送至那台服务器的那个目录,使用的是什么用户
        [root@backup ~]# rsync -avz ./backup_file root@172.16.1.31:/opt/
        root@172.16.1.31's password:        #输入31的root密码

下载    Pull: rsync [OPTION...] [USER@]HOST:SRC... [DEST]
              命令    选项     系统用户 主机IP  
        2.我要下载那个主机的那个目录下的文件,使用的是什么系统用户.  然后下载到我本地的那个位置 
        [root@backup ~]# rsync -avz root@172.16.1.31:/opt/backup_file   ./file.txt

PS:
Rsync借助SSH协议同步数据存在的缺陷    (  使用对端主机的用户名和密码   系统  )
    1.使用系统用户(不安全)
    2.使用普通用户(会导致权限不足情况)
    
问题:
    1.rsync -avz /etc/ root@172.16.1.31:/opt          ---> 172.168.1.31
    2.路径问题
    3.普通用户权限

3)**守护进程 ---> **

1.安装
[root@backup ~]# yum install rsync -y

2.配置   ( 改变程序运行轨迹  )
[root@backup ~]# cat /etc/rsyncd.conf
uid = rsync
gid = rsync
port = 873
fake super = yes
use chroot = no
max connections = 200
timeout = 600
ignore errors
read only = false
list = false
auth users = rsync_backup
secrets file = /etc/rsync.passwd
log file = /var/log/rsyncd.log
#####################################
[backup]
comment = welcome to oldboyedu backup!
path = /backup
    
3.根据配置创建一些初识环境:
        
3.1创建rsync用户    rsync程序需要rsync这个用户来运行
[root@backup ~]# groupadd rsync
[root@backup ~]# useradd -M -s /sbin/nologin rsync -g rsync
[root@backup ~]# id rsync
uid=1000(rsync) gid=1000(rsync) groups=1000(rsync)

3.2 虚拟用户    /etc/rsync.passwd      username:password
[root@backup ~]# echo "rsync_backup:123456" > /etc/rsync.passwd
[root@backup ~]# chmod 600 /etc/rsync.passwd
            
3.3 创建一个/backup目录
[root@backup ~]# mkdir /backup
[root@backup ~]# chown -R rsync.rsync /backup/
        
4.启动
[root@backup ~]# systemctl start rsyncd
[root@backup ~]# systemctl enable rsyncd
        
5.检测
[root@backup ~]# netstat -lntp | grep 873
        tcp        0      0 0.0.0.0:873       0.0.0.0:*        LISTEN    8616/rsync          
        
6.使用
Push: rsync [OPTION...] SRC... [USER@]HOST::DEST
[root@nfs ~]# rsync -avz ./anaconda-ks.cfg  rsync_backup@172.16.1.41::backup
        
Pull: rsync [OPTION...] [USER@]HOST::SRC... [DEST]
[root@nfs ~]# rsync -avz rsync_backup@172.16.1.41::backup /opt

7.客户端每次都需要使用密码?
    1.设定变量  RSYNC_PASSWORD  (后面写脚本的时候)
    [root@nfs ~]# export RSYNC_PASSWORD=123456   #暂时的修改变量
    [root@nfs ~]# rsync -avz rsync_backup@172.16.1.41::backup /opt

    2.提前准备一个文件 (只有密码的文件),  然后使用 --password-file 指定位置
    [root@nfs ~]# echo "123456" >  /etc/rsync.pass
    [root@nfs ~]# chmod 600 /etc/rsync.pass
    [root@nfs ~]# rsync -avz rsync_backup@172.16.1.41::backup /opt --password-file=/etc/rsync.pass

8.-avz 这些选项  怎么理解?
    -a           #归档模式传输, 等于-tropgDl
    -v           #详细模式输出, 打印速率, 文件数量等
    -z           #传输时进行压缩以提高效率
    -r           #递归传输目录及子目录,即目录下得所有目录都同样传输。
    -t           #保持文件时间信息
    -o           #保持文件属主信息
    -p           #保持文件权限
    -g           #保持文件属组信息
    -l           #保留软连接
    -D           #保持设备文件信息
    -P           #显示同步的过程及传输时的进度等信息
    -L           #保留软连接指向的目标文件
    -e           #使用的信道协议,指定替代rsh的shell程序
    --exclude=PATTERN   #指定排除不需要传输的文件模式
    --exclude-from=file #文件名所在的目录文件
    --bwlimit=100       #限速传输,默认单位KB
    --delete            #让目标目录和源目录数据保持一致

9. --delete

--delete    #这个参数是让目标目录和源目录数据保持一致   特危险

#推:源有什么,目标就有什么
[root@nfs ~]# rsync -avz /root/ rsync_backup@172.16.1.41::backup --delete

#拉: 目标有什么,本地就变成什么
[root@nfs ~]# rsync -avz rsync_backup@172.16.1.41::backup ./ --delete

10. --bwlimit

--bwlimit   #限速   默认单位  KB
[root@nfs ~]# rsync  -avzP --bwlimit=5120  ubuntu-18.04.1-desktop-amd64.iso  rsync_backup@172.16.1.41::backup
        

11. --exclude

--exclude           #排除

#排除单个文件
[root@nfs ~]# rsync  -avzP --exclude=centos/  rsync://192.168.0.128/yum  ./    #将这个网络文件同步到本地当前文件夹内,并排除centos/这个文件

--exclude-form
#排除多个文件 
[root@nfs ~]# vim 1.txt             #将需要排除的文件名称写到文件内
[root@nfs ~]# rsync  -avzP --exclude-from=1.txt  rsync://192.168.0.128/yum  ./       #同步网络文件时,排除1.txt的目录


相关文章

  • 第三十二天 rsync 远程连接

    RSYNC远程同步 1.什么是备份 给源文件准备一个副本,就是备份 2.为什么要做备份? 1)数据重要 2)防止误...

  • rsync命令

    rsync 基于 ssh 和 rsh 服务实现高效的远程系统之间复制文件 使用安全的 shell 连接作为传输方式...

  • 文件同步rsync

    rsync 远程同步rsync(remote sync) 备份 rsync 优点: 支持增量备份选择性保持:符号链...

  • 详解rsync,一款卓越的增量同步工具(一)

    一、Rsync是什么? Rsync (remote rsync) 是可以实现增量备份的远程(和本地)文件复制工具,...

  • 远程文件复制

    1.scp 从远程复制到本地 从本地复制到远程 2.rsync 从远程复制到本地 从本地复制到远程 注:rsync...

  • Rsync 配置和使用

    Rsync 远程同步主要有两种方式:使用远程shell(ssh或rsh) 或使用rsync的daemon方式 常用...

  • Linux_277_rsync远程传输实践

    rsync远程传输命令实践1、分别在3台linux虚拟机上安装rsync服务yum install rsync -...

  • Rsync 命令的基本使用

    Rsync的介绍 远程数据同步工具,支持本地复制与远程同步,优于scp,cp。rsync基础采用c/s架构,监听端...

  • linux inotify机制监听文件状态

    1.介绍 rsync + inotify 组合的起源Rsync(remote sync)远程同步工具,通过rsy...

  • DAY06(02):rsync+SSH同步

    2 案例2:rsync+SSH同步 2.1 问题 本例要求掌握rsync与远程SSH资源的同步操作,使用rsync...

网友评论

      本文标题:第三十二天 rsync 远程连接

      本文链接:https://www.haomeiwen.com/subject/ozfjyctx.html