rsync远程同步

rsync远程同步: 是一个开源的快速备份工具。可以在不同主机之间同步整个目录

在远程,一个是源端,一个是发起端。

源端负责文件原始位置,发起端和源端文件同步。

拷贝文件,连接文件,设备

可以保持源文件或者目录的权限不变 时间、软连接、所有者,所有组等均可以保持不变

可以实现增量同步。只同步发生变化的数据,数据传输效率很高支持匿名认证。

适合同步大文件,可与数据库同步

同步方式

1、完整备份,第一次同步都是完整备份

2、往后的同步,都是增量备份(差异备份),只同步变化的数据。

rsync的命令选项

-r 递归模式,目录包含子目录里免得所有内容。

-l 复制链接文件,软连接

-v 显示同步过程中的详细信息

-z 文件传输,进行压缩

-a 归档模式,可以保留文件按的权限、属性等待

-p 保留文件的权限标记(所有者、所有组)

-t 保留时间标记(时间戳)

-g 保留文件的所在组(管理员)

-o 保留文件的所在者(管理员)

-H 保留硬链接

-D: 保留设备文件和其他特殊文件

--delete: 删除目标位置有,但是原始位置没有的文件

下行同步:

从源端同步到客户端

上行同步

从客户端同步到源端

test1 源端

test2 客户端

下行同步

systemctl stop firewalld

setenforce 0

vim /etc/rsyncd.conf

***************************************

uid = root

gid = root

use chroot = yes

#禁锢在源文件

address = 192.168.10.10

#监听地址

port = 873

#监听端口

log file = /var/log/rsync.log

pid file = /var/run/rsyncd.pid

hosts allow = 192.168.10.0/24

#指定可以访问服务端的地址

取消注释:以上述后缀名的,同步时不进行压缩

配置共享模块和目录、账户、密码

test1

path = /opt/test

comment = test

read only = no

auth users = backuper

secrets file = /etc/rsyncd_users.db

***************************************

vim /etc/rsyncd_users.db

***************************************

backuper:123456

***************************************

chmod 600 /rsyncd_users.db

mkdir -p /opt/test

chmod 777 /opt/test

rsync --daemon 重启

netstat -antp | grep rsync

kill $(cat /var/run/rsyncd.pid) 关闭服务

cd /opt/test

创建文件到/opt/test

test2

rsync -avz ++++backuper@192.168.10.102::test++++ /opt/

rsync 发起同步的命令

-avz a保留文件权限 v显示详细过程 z同步过程中对文件进行压缩

++++:test++++ 模块名称

免密交换

test2

echo"123456"> /etc/server.pass

chmod 600 /etc/server.pass

rsync -avz --password-file=/etc/server.pass ++++backuper@192.168.10.10::test++++ /opt

inotifv通知接口,可以用来监控文件系统的各种变化情况,文件存取,删除,移动,修改都可以被监控

inotifv机制和rsync配合使用。既可以通知变化,也可以实现同步

tar -xf inotify-tools-3.14,tar.gz

监控事件队列

最多监控的实例

每个实例最多监控的文件

vim /etc/sysctl.conf

********************************

fs.inotify.max_queued_events = 16384

fs.inotify.max_user_instances = 1024

fs.inotify.max_user_watches = 1048576

********************************

sysctl -p

./configure

make && make install

test1

vim /etc/rsyncd.conf

read only = no

test2

inotifywait -mrq -e modify,create,move,delete /opt/test/

-m 持续监控

-r 递归整个目录

-q 简化的输出信息,信息提示

-e 指定监控的事件,多个事件用逗号隔开

rsync -avz --password-file=/etc/server.pass /opt/data ++++backuper@192.168.10.10::test++++ /opt

创建一个监控脚本

CMD="inotifywait -mrq -e modify,create,move,delete /opt/data/"

rsync_cmd="rsync -avz --password-file=/etc/server.pass /opt/data ++++backuper@192.168.10.10::test++++"

$CMD | while read DIRECTORY EVENT FILE

do

if[ $(pgrep rsync | wc -l) -le 0 ]

then

$rsync_cmd

fi

done

给脚本777权限

chmod +x /etc/rc.d/rc.local

echo '/opt/inotify.sh' >> /etc/rc.d/rc.local

crontab -e -u root

* * * * * /opt/inotify.sh

快速删除大量文件

创建一个空文件

rsync --delete-before -a -H -v --progress --stats /home/blank/ /opt/test1

--delete-before 在传输的过程中进行删除

-a 归档

-H 硬链接

-v 输出过程信息

--progress 显示传输过程

两个文件一样

相关推荐
运维成长记4 小时前
阿里云错题集分享
阿里云·云计算
云资源服务商4 小时前
探秘阿里云消息队列:解锁分布式系统的异步通信奥秘
阿里云·中间件·云计算
bennybi4 小时前
阿里云-跨账号同步OSS Bucket
阿里云·云计算
互联网搬砖老肖4 小时前
运维打铁: 阿里云 ECS 实例的高效运维与管理
运维·阿里云·云计算
xiao5kou4chang6kai47 小时前
Python-GEE遥感云大数据分析与可视化(如何建立基于云计算的森林监测预警系统)
python·数据分析·云计算·森林监测·森林管理
ZStack开发者社区15 小时前
首批 | 云轴科技ZStack加入施耐德电气技术本地化创新生态
人工智能·科技·云计算
爱思德学术18 小时前
中国计算机学会(CCF)推荐学术会议-B(计算机体系结构/并行与分布计算/存储系统):SOCC 2025
网络协议·机器学习·云计算·边缘计算
Britz_Kevin1 天前
从零开始的云计算生活——番外2,MySQL组复制
数据库·mysql·云计算·生活·#组复制
AKAMAI1 天前
在Akamai平台上进行VOD转码的参考架构
后端·云原生·云计算
科技云报道1 天前
科技云报到:云智融合双buff,AI已开挂
云计算