ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

备份软件 rsync

2021-12-30 02:02:27  阅读:166  来源: 互联网

标签:opt 文件 rsync -- backup 备份 软件 root


  备份方式
  1. cp 本机复制
  2. scp 远程复制
    1. 推  (本地上传到远程服务器)
      • 格式
        • scp 1.txt root@ip:[路径]
        • [root@m01 ~]# scp 1.txt root@172.16.1.41:/opt/
    2. 拉  (远程服务器文件下载到本地)
      • 格式
        • scp root@ip:[路径] ./
        • [root@m01 ~]# scp root@172.16.1.41:/opt/2.txt
  3. rsync 远程复制
    • 支持 增量复制
  ------ rsync ------   概要   1 介绍 2 特性 3 应用场景(备份方式) 4 传输方式 5 传输模式 6 参数 7 rsync守护进程模式(目的:实现实时备份) ---服务端 ---客户端 ---实时同步     详细       1 介绍   rsync英文称为remote synchronizetion,从软件的名称就可以看出来,rsync具有可使本地和远程两台主机之间的数据快速复制同步镜像、远程备份的功能,这个功能类似于ssh带的scp命令,但是又优于scp命令的功能,scp每次都是全量拷贝,而rsync可以增量拷贝。当然,rsync还可以在本地主机的不同分区或目录之间全量及增量的复制数据,这又类似cp命令。但是同样也优于cp命令,cp每次都是全量拷贝,而rsync可以增量拷贝。   rsync官方地址:https://rsync.samba.org/ rsync监听端口:873 rsync运行模式:C/S   client/server     rsync简称叫做远程同步,可以实现不同主机之间的数据同步,方式全量和增量   2 特性   支持拷贝特殊文件,如连接文件、设备等 可以有排除指定文件或目录同步的功能,相当于打包命令tar的排除功能 可以做到保持原文件或目录的权限、时间、软硬链接、属主、组等所有属性均不改变 –p 可以实现增量同步,既只同步发生变化的数据,因此数据传输效率很高(tar-N) 可以使用rcp、rsh、ssh等方式来配合传输文件(rsync本身不对数据加密) 可以通过socket(进程方式)传输文件和数据(服务端和客户端)***** 支持匿名的活认证(无需系统用户)的进程模式传输,可以实现方便安全的进行数据备份和镜像     3 应用场景(备份方式)  
  • 全量备份
    • 每次都是从头开始复制
  • 增量备份
    • 接续上次复制
  4 传输方式  
  1. push
    • 数据从本地(客户端)推送至服务端
  2. pull
    • 数据从服务端拉取到本地(客户端)
  5 传输模式  
  1. 本地方式(类似cp)
  2. 远程方式
    • 类似于scp,又不同于scp, scp只支持全量备份,rsync支持增量备份和差异备份
  3. 守护进程方式(客户端和服务端)
    • 借助inotify这个软件来实现实时同步
  6 rsync参数使用   上传文件   格式: sync -azvP 本地文件路径 root@远程PC的IP 冒号 远程PC文件路径   下载文件   格式: sync -azvP  root@远程PC的IP 冒号 远程PC文件路径 本地文件路径   详细
  • -a           #归档模式传输, 等于-tropgDl    -t -r -o -p -g -D -l
  • -v           #详细模式输出, 打印速率, 文件数量等
  • -P           #显示同步的过程及传输时的进度等信息
  • -z           #传输时进行压缩以提高效率
  • 其他(1)
  • -r           #递归传输目录及子目录,即目录下得所有目录都同样传输
  • -t           #保持文件时间信息
  • -o           #保持文件属主信息
  • -g           #保持文件属组信息
  • -p           #保持文件权限
  • -l           #保留软连接
  • -D           #保持设备文件信息
  • -L           #保留软连接指向的目标文件
  • -e           #使用的信道协议,指定替代rsh的shell程序(很少用)
  • 其他
  • --append            # 指定文件接着上次传输中断处继续传输
    • [root@m01 ~]# rsync -azvP --append 2.txt root@172.16.1.41:/root/test
  • --append-verify     # 使用参数续传(在断点续传之后,验证一下文件:  如果文件有修改,从头开始传; 没有,从断点处传输)
  • --exclude=PATTERN   # 指定排除不需要传输的文件
    • [root@m01 ~]# rsync -avzP --append-verify --exclude=2.txt  ./* root@172.16.1.41:/opt/
  • --exclude-from=file # 按照文件指定内容排除
    • [root@m01 ~]# rsync -avzP --append-verify --exclude-from=/tmp/exclude.txt  ./* root@172.16.1.41:/opt/
  • --bwlimit=100       # 限速传输(单位:MB)
    • [root@m01 ~]# rsync -avzP --append-verify --bwlimit=10  ./* root@172.16.1.41:/opt/
  • --delete            # 让目标目录和源目录数据保持一致
  • --password-file=xxx # 使用密码文件
  • --port              # 指定端口传输
    7 rsync守护进程模式
  • 目的:实现实时备份
  step1---服务端   1-1 # 安装rsync软件 [root@backup ~]# yum install -y rsync   1-2 # 修改配置文件   [root@backup opt]# vim /etc/rsyncd.conf     注意:编辑完再进去检查下,[backup]后边行确认无注释的# 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 backup! path =/backup [linux] comment = welcome to linux! path=/tmp/linux       配置详解   1-3 # 创建系统用户 [root@backup opt]# groupadd rsync -g 666 [root@backup opt]# useradd rsync -u 666 -g 666 -M -s /sbin/nologin -r     -M 指定创建系统用户; /nologin 不需要登陆   1-4 # 创建密码文件 [root@backup opt]# echo "rsync_backup:123456" > /etc/rsync.passwd     格式:     echo "虚拟用户名(配置文件里):新设定密码" 密码路径(配置文件里)   1-5 # "密码文件"授权(必须授权为600) [root@backup opt]# chmod 600 /etc/rsync.passwd   1-6 # 创建备份目录 [root@backup opt]# mkdir /backup [root@backup opt]# mkdir /tmp/linux      1-7 # 目录授权 [root@backup opt]# chown rsync.rsync /backup/ [root@backup opt]# chown rsync.rsync /tmp/linux/     创建的目录---默认属主数组是root,启动的应用程序是rsync,这些目录没有权限,所以需要授权   1-8 # 关闭防火墙和selinux [root@backup opt]# systemctl disable --now firewalld [root@backup opt]# setenforce 0   1-9 # 启动rsyncd服务 [root@backup opt]# systemctl start rsyncd   演示       step2 ---在客户端测试
  • 在客户端上传资料到"服务端rsync"
  • 方式: 3中
  方法一:自己输入密码   [root@m01 ~]# rsync -avzP ./* rsync_backup@172.16.1.41::backup
  • rsync_backup : 虚拟用户,只在数据传输时使用
  • 172.16.1.41  : backup服务端的IP
  • backup       : 模块名称(注意语句中前边是两个冒号)
        方法二:设置密码文件,运行时读取 待补看视频实际练
  1. 编写密码文件
    • [root@backup opt]# echo "123456" > /etc/rsync.passwd
  2. 授权"密码文件"
    • [root@m01 ~]# chmod 600 /etc/rsync.passwd
  3. 上传备份
    • [root@m01 ~]# rsync -avzP --password-file=/etc/rsync.passwd  ./* rsync_backup@172.16.1.41::linux
  方法三:添加环境变量(很少用,) 待补看视频实际练
  1. 定义环境变量
    • export RSYNC_PASSWORD=123456
  2. 上传备份
    • [root@m01 ~]# rsync -avzP  ./* rsync_backup@172.16.1.41::linux
    ---实时同步   rsync是不支持实时同步的,通常我们借助于inotify这个软件来实时监控文件变化,一旦inotify监控到文件变,则立即调用rsync进行同步     1、安装inotify(装在客户端) [root@web01 ~]# yum -y install inotify-tools   2、inotify参数介绍 -m 持续监控 -r 递归 -q 静默,仅打印时间信息 --timefmt 指定输出时间格式 --format 指定事件输出格式     %Xe 事件     %w 目录     %f 文件 -e 指定监控的事件     access 访问     modify 内容修改     attrib 属性修改     close_write 修改真实文件内容     open 打开     create 创建     delete 删除     umount 卸载      3、开始监控 [root@m01 ~]# /usr/bin/inotifywait  -mrq  --format '%Xe  %w  %f' -e create,modify,delete,attrib,close_write  /root     4、实时监控并同步     实际操作 [root@m01 ~]# /usr/bin/inotifywait  -mrq  --format '%Xe  %w  %f' -e create,modify,delete,attrib,close_write  /root | while read line;do     cd  /root     rsync -avzP --delete --password-file=/etc/rsync.passwd ./* rsync_backup@172.16.1.41::backup done            ---补充:   创建固定大小文件  
  • dd if=/dev/zero of=3.txt bs=100M count=10
  修改 属主属组                                

标签:opt,文件,rsync,--,backup,备份,软件,root
来源: https://www.cnblogs.com/tslam/p/15747307.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有