rsync远程同步

一 rsync服务
1.基本语法
NAME
rsync — a fast, versatile, remote (and local) file-copying tool         
//⼀种快速、通⽤、远程(和本地)的⽂件复制⼯具
SYNOPSIS         //本地⽂件同步
        Local:rsync [OPTION...] SRC... [DEST]
        //远程⽂件同步 PUSH:推,相当于上传;PULL:拉,相当于下载
2、OPTION选项说明
-v 详细模式输出
-a 归档模式,递归的⽅式传输⽂件,并保持⽂件的属性,equals -rlptgoD
-r 递归拷⻉⽬录
-l 保留软链接
-p 保留原有权限
-t 保留原有时间(修改)
-g 保留属组权限
-o 保留属主权限
-D 等于--devices --specials 表示⽀持b,c,s,p类型的⽂件
-R 保留相对路径
-H 保留硬链接
-A 保留ACL策略
-e 指定要执⾏的远程shell命令,ssh更改端⼝常⽤选项
-E 保留可执⾏权限
-X 保留扩展属性信息 a属性
(1)本地文件同步命令
本地⽂件同步简单理解就是把⽂件从⼀个位置(同步=>拷⻉)到另外⼀个位置(类似cp)
# rsync -av /dir1/ /dir2          //把/dir1⽬录中的所有⽂件拷⻉到/dir2⽬录中
# rsync -av /dir1 /dir3          //把/dir1⽬录整体同步到/dir3⽬录中
# rsync -av --delete /dir1/ /dir2        //自动删除dir2文件夹的多余文件,保持dir2和dir1的高度一致
(2)远程文件同步命令

rsync -ac 源 用户@主机地址

获取数据pull拉取  push推送

[root@localhost ~]# yum -y install rsync    //另一台主机也需要安装rsync
[root@aa ~]# rsync -av folder/ root@192.168.8.132:/tmp/
[root@localhost ~]# ls /tmp/
[root@localhost ~]# dd if=/dev/zero of=/tmp/lajiwenjain bs=300M count=1
[root@localhost ~]# ls /tmp/ -lh
[root@aa ~]# rsync -av root@192.168.8.132:/tmp/lajiwenjain /tmp/   //从远程主机拉取数据
[root@aa ~]# ls -lh /tmp/ | grep lajiwenjain
-rw-r--r-- 1 root root 300M 7月  18 11:04 lajiwenjain


rsync作为系统服务
 查找rsync主配置文件

[root@aa ~]# systemctl start rsyncd
[root@aa ~]# netstat -lntup |grep rsync    //使用873端口
[root@aa ~]# find / -name "rsync*conf"   //找配置文件
/etc/rsyncd.conf
[root@aa ~]# vim /etc/rsyncd.conf
# uid = nobody    用户编号
# gid = nobody    所属组编号
# use chroot = yes    是否禁锢目录
# max connections = 4    最大连接数
# pid file = /var/run/rsyncd.pid    进程文件,每个服务都有一个PID编号,其来源就是PID文件
# exclude = lost+found/   传输文件时,忽略lost+fiund/目录
# transfer logging = yes    传输日志是否需要写入日志文件,yes表示写入
# timeout = 900     传输超时时间,默认15分钟
# ignore nonreadable = yes    是否忽略不可读文件
# dont compress   = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2   以下格式文件不压缩
[root@aa ~]# mkdir -p /app/studentweb/src/main/java/co/goho/yuanyu.studentweb/
[root@aa ~]# tree /app/
/app/
└── studentweb
    └── src
        └── main
            └── java
                └── co
                    └── goho
                        └── yuanyu.studentweb
[root@aa ~]# touch /app/studentweb/src/main/java/co/goho/yuanyu.studentweb/File{0..9}.java
[root@aa ~]# tree /app/

把rsync作为系统服务运行


在aa主机中提供了一个针对app/下的项目rsync服务,下一次直接找服务 

[root@aa ~]# cd /app/studentweb/     //复制路径
[root@aa studentweb]# vim /etc/rsyncd.conf
[root@aa studentweb]# systemctl restart rsyncd
[root@localhost ~]# rsync -a root@192.168.8.131::
app 
[root@localhost ~]# rsync -a root@192.168.8.131::app /tmp/   //拉取
[root@localhost ~]# ls -l /tmp/ |grep src
drwxr-xr-x. 3 root root        18 7月  18 11:28 src
[root@localhost ~]# tree /tmp/src/
自动化推送拉去文件
每30秒推送一次,编辑计划任务命令 crontab -e

[root@aa ~]# which rsync
/usr/bin/rsync
[root@aa ~]# crontab -e
*/1 * * * * /usr/bin/rsync -av /app/studentweb/ root@192.168.
8.132:/tmp/
[root@localhost ~]# rm -rf /tmp/*
[root@localhost ~]# ls /tmp/
自动监听文件被修改行为,在自动推送

二、RSYNC课程扩展
1、给rsyncd服务添加密码
        1.1修改配置文件添加两个属性   
auth users=user0,user1    (账号和免密路径) 

secrets file=/etc/rsync.secrets

[root@aa ~]# vim /etc/rsyncd.conf
[app]
path=/app/studentweb/
Log file=/var/log/rsync. log
auth users=zahngsan, lisi
secrets file=/etc/resync. secrets
        1.2编辑rsync密码

[root@aa ~]# vim /etc/resync.secrets
zhangsan:zhangsan
lisi:lisi
        1.3给/etc/resync.secrets添加权限并重启

[root@aa ~]# chmod 600 /etc/resync.secrets
[root@aa ~]# ls -l /etc/resync.secrets
-rw------- 1 root root 28 7月  18 15:11 /etc/resync.secrets
[root@aa ~]# systemctl restart rsyncd
        1.4拉取数据

[root@localhost ~]# rsync -av zhangsan@192.168.8.131::app /tmp/
2、rsync集合inotify工具实现代码实时同步
        2.1直接安装inotify-tools
监听指定目录,一旦目录发生修改,就执行指令命令

[root@aa ~]# yum -y install inotify-tools
        2.2inotify 监听
安装完后,就会产生下面两个命令
/usr/bin/inotifywait    等待
/usr/bin/inotifywatch   看守

[root@aa ~]# inotifywait -mr /app/     
[root@aa ~]# touch /app/studentweb/woshiqinshihuan.txt   
另开终端创建文件,inotifywhit监听到目录改变就会被推送

        2.3编写inotify.sh
[root@aa ~]# vim inotifytest

选项    说明
-m    一直监控某个目录,create,delete,modify等行为
-r    递归,不仅仅监控目录还要监控目录下的文件
-q    获取操作信息,但是不能输出
-e    哪些行为需要被监控,modify,delete,create,attrib,move
modify    文件被修改
delete    文件被删除
create    文件被创建
attrib    文件属性被修改
move    文件被移动
[root@aa ~]# mv inotifytest inotifytest.sh
[root@aa ~]# chmod 700 inotifytest.sh 

[root@aa ~]# ./inotifytest.sh

另开一个终端创建文件,会监听信息

[root@aa ~]# touch /app/studentweb/nihaowoshiqingshihuang.txt

2.4让inotifytest.sh文件在后台一直运行
nohup:在后台一直运行,即使终端关闭

&:让inotify.sh在计算机后台运行,可以使用jobs命令查看,kill %编号结束,当我
们退出终端时,这个执行会自动结束

[root@aa ~]# nohup ./inotifytest.sh &

3.如何查看rsync.log⽇志⽂件
[root@aa ~]## cat /var/log/rsync.lo

1、新增账号 zhangsan lisi wangwu zhaoliu aaa bbb ccc ddd
 

练习

[root@2 ~]# useradd zhangsan
 [root@2 ~]# useradd lisi
 [root@2 ~]# useradd wangwu
 [root@2 ~]# useradd zhaoliu
 [root@2 ~]# useradd aaa
 [root@2 ~]# useradd bbb
 [root@2 ~]# useradd ccc
 [root@2 ~]# useradd ddd
2、设置和账号同名的如果长度不够8位就重复账号
 

[root@2 ~]# echo zhangsan | passwd --stdin zhangsan
 更改用户 zhangsan 的密码 。
 passwd:所有的身份验证令牌已经成功更新。
 [root@2 ~]# echo lisi | passwd --stdin lisi
 更改用户 lisi 的密码 。
 passwd:所有的身份验证令牌已经成功更新。
 [root@2 ~]# echo wangwu | passwd --stdin wangwu
 更改用户 wangwu 的密码 。
 passwd:所有的身份验证令牌已经成功更新。
 [root@2 ~]# echo zhaoliu | passwd --stdin zhaoliu
 更改用户 zhaoliu 的密码 。
 passwd:所有的身份验证令牌已经成功更新。
 [root@2 ~]# echo aaa | passwd --stdin aaa
 更改用户 aaa 的密码 。
 passwd:所有的身份验证令牌已经成功更新。
 [root@2 ~]# echo bbb | passwd --stdin bbb
 更改用户 bbb 的密码 。
 passwd:所有的身份验证令牌已经成功更新。
 [root@2 ~]# echo ccc | passwd --stdin ccc
 更改用户 ccc 的密码 。
 passwd:所有的身份验证令牌已经成功更新。
 [root@2 ~]# echo ddd | passwd --stdin ddd
 更改用户 ddd 的密码 。
 passwd:所有的身份验证令牌已经成功更新。

3、设置这些账户都有对code目录w的权限

 [root@2 ~]# groupadd code
 [root@2 ~]# usermod -g code zhangsan
 usermod:无改变
 [root@2 ~]# usermod -g code lisi
 usermod:无改变
 [root@2 ~]# usermod -g code wangwu
 [root@2 ~]# usermod -g code zhaoliu
 [root@2 ~]# usermod -g code aaa
 [root@2 ~]# usermod -g code bbb
 [root@2 ~]# usermod -g code ccc
 [root@2 ~]# usermod -g code ddd
 [root@2 ~]# mkdir /code/
 [root@2 ~]# chown root:code /code
 验证
 [zhangsan@2 ~]$ touch /code/zhangsan
 [lisi@2 ~]$ touch /code/lisi
 [wangwu@2 ~]$ touch /code/wangwu
 [zhaoliu@2 ~]$ touch /code/zhaoliu
 [aaa@2 ~]$ touch /code/aaa
 [bbb@2 ~]$ touch /code/bbb
 [ccc@2 ~]$ touch /code/ccc
 [ddd@2 ~]$ touch /code/ddd
 [root@2 ~]# ls /code/
 aaa  bbb  ccc  ddd  lisi  wangwu  zhangsan  zhaoliu
4、为以上的用户设置免密登录
 

假设aaa为服务器
 [lisi@2 ~]$ ssh-keygen
 [wangwu@2 ~]$ ssh-keygen 
 [zhaoliu@2 ~]$ ssh-keygen
 [bbb@2 ~]$ ssh-keygen
 [ccc@2 ~]$ ssh-keygen
 [ddd@2 ~]$ ssh-keygen 
 [lisi@2 ~]$ ssh-copy-id aaa@10.0.0.20
 [wangwu@2 ~]$ ssh-copy-id -p9999 aaa@10.0.0.20
 [zhaoliu@2 ~]$ ssh-copy-id -p9999 aaa@10.0.0.20
 [bbb@2 ~]$ ssh-copy-id -p9999 aaa@10.0.0.20
 [ccc@2 ~]$ ssh-copy-id -p9999 aaa@10.0.0.20
 [ddd@2 ~]$ ssh-copy-id -p9999 aaa@10.0.0.20

实现监控并远程同步
1.编写脚本
# vim inotify.sh
#!/bin/bashinotifywait -mrq -e modify,delete,create,attrib,move
/app/java_project |while read events
do
       rsync -av  /app/studentweb/ root@192.168.10.126:/tmp/
        echo "`date +%F\ %T`出现事件$events" >> /var/log/rsync.log 2>&1
done
# 保存退出
2.添加可执行权限
# chmod 700 inotify.sh 

3.实现后台监控
# nohup ./inotify.sh &

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值