搜索
查看
编辑修改
首页
UNITY
NODEJS
PYTHON
AI
GIT
PHP
GO
CEF3
JAVA
HTML
CSS
搜索
繁依Fanyi0
这个屌丝很懒,什么也没留下!
关注作者
热门标签
jquery
HTML
CSS
PHP
ASP
PYTHON
GO
AI
C
C++
C#
PHOTOSHOP
UNITY
iOS
android
vue
xml
爬虫
SEO
LINUX
WINDOWS
JAVA
MFC
CEF3
CAD
NODEJS
GIT
Pyppeteer
article
热门文章
1
macbook pro下SVN客户端macSvn使用_mac svn客户端
2
图像生成基础
3
最全Golang 区块链开发指南,Golang面试官_golang区块链开发
4
PyTorch中的预训练模型_pytorch预训练模型有哪些
5
为什么阿里巴巴Java开发规范中建议谨慎使用 Arrays.asList() 方法_java arrays.aslist 性能怎么样
6
替代Google的七款最优秀语义搜索引擎_类似于duckduckgo
7
软件工程学习笔记7——需求分析篇_软件工程需求分析知识点总结
8
Docker常用命令_docker rm -f
9
从Win11 系统SSLVPN无法登录故障浅谈达梦数据库安全性_ssl无法连接 win11系统重装
10
mac 安装 ffmpeg_mac安装ffmpeg
当前位置:
article
> 正文
云计算day09
作者:繁依Fanyi0 | 2024-08-06 03:18:52
赞
踩
云计算day09
Linux系统下数据同步服务RSYNC
⼀、RSYNC概述
1、什么是rsync
rsync的好姐妹
sync 同步:刷新⽂件系统缓存,强制将修改过的数据块写⼊磁盘,并且更新超级块。
async 异步:将数据先放到缓冲区,再周期性(⼀般是30s)的去同步到磁盘。
rsync 远程同步:==remote synchronous==
数据同步过程
sync数据同步 => 保存⽂件(⽬标)=> 强制把缓存中的数据写⼊磁盘(⽴即保存),实时性
要求⽐较⾼的场景
asyn数据异步 => 保存⽂件(⽬标)=> 将数据先放到缓冲区,再周期性(⼀般是30s)的去同
步到磁盘,适合⼤批量数据同步的场景
2、rsync特点
可以镜像保存整个⽬录树和⽂件系统
可以保留原有的权限(permission,mode),owner,group,时间(修改时间,modify time),软硬
链接,⽂件acl,⽂件属性(attributes)信息等
传输==效率⾼==,使⽤同步算法,只⽐较变化的(增量备份)file1.txt file2.txt file3.txt(A服务器)
rsync实现数据同步 => 只同步file3.txt => 增量备份
file1.txt file2.txt(B服务器)
⽀持匿名传输,⽅便⽹站镜像;也可以做验证,加强安全
3、rsync与scp的区别
两者都可以实现远程同步,但是相对⽐⽽⾔,rsync能⼒更强
① ⽀持增量备份
② 数据同步时保持⽂件的原有属性
yum -y install rsync
⼆、RSYNC的使⽤
1、基本语法
Tar -zcvf. Zxvf.
rpm -ivh
# man rsync
NAME
rsync — a fast, versatile, remote (and local) file-copying tool
//⼀种快速、通⽤、远程(和本地)的⽂件复制⼯具
SYNOPSIS
//本地⽂件同步
Local:rsync [OPTION...] SRC... [DEST]
//远程⽂件同步PUSH:推,相当于上传;PULL:拉,相当于下载
2、本地⽂件同步
本地⽂件同步简单理解就是把⽂件从⼀个位置(同步=>拷⻉)到另外⼀个位置(类似cp)
案例:/dir1、/dir2与/dir3,/dir1中创建三个⽂件file1、file2、file3,使⽤rsync本地同步
Access via remote shell:
Pull: rsync [OPTION...] [USER@]HOST:SRC... [DEST]
Push: rsync [OPTION...] SRC... [USER@]HOST:DEST
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属性案例:rsync -R选项的应⽤(保留相对路径)
案例:rsync --delete(删除⽬标⽬录⾥多余的⽂件)
/dir1
===
/dir2
file1、file2
file1、file2、file3
rsync --delete同步后,会⾃动删除file3⽂件。(让dir1与dir2⽬录中的⽂件⾼度⼀致)
3、远程⽂件同步
要实现时远程同步,要求两台主机都应该安装rsync
Push:上传⽂件到远程服务器端
案例:把linux.txt⽂档传输到远程服务器端(10.1.1.100)
# mkdir /dir1
# mkdir /dir2
# mkdir /dir3
# touch /dir1/file{1..3}
# rsync -av /dir1/ /dir2 => 把/dir1⽬录中的所有⽂件拷⻉到/dir2⽬录中
# rsync -av /dir1 /dir3 => 把/dir1⽬录整体同步到/dir3⽬录中
# rsync -avR /dir1/ /dir2
# rsync -av --delete /dir1/ /dir2
# rsync -av 本地⽂件或⽬录 远程⽤户名@远程服务器的IP地址:⽬标路径
# rsync -av linux.txt案例:把shop⽂件夹传输到远程服务器端(10.1.1.100)
# rsync -av shop root@10.1.1.100:/root
Pull:下载⽂件到本地服务器端
# rsync -av 远程⽤户名@远程服务器的IP:⽬标⽂件或⽬录 本地存储位置
案例:把远程服务器(10.1.1.100)的/etc/hosts⽂件下载到本地
# rsync -av root@10.1.1.100:/etc/hosts ./
案例:把远程服务器(10.1.1.100)的/shop⽂件夹下载到本地
# rsync -av root@10.1.1.100:/shop ./
思考:
问题1:rsync远程同步数据时,默认情况下为什么需要密码?如果不想要密码同步怎么实现?
rsync在远程同步时,之所以要输⼊密码的主要原因在于其底层还是基于SSH服务的。SSH有
两种认证⽅式,如果没有配置免密则默认使⽤⽤户名+密码的认证⽅式。
不想要密码同步,可以考虑使⽤SSH免密操作。
Code => Backup
Code:
# ssh-keygen -t rsa -P ""
# ssh-copy-id root@10.1.1.100
问题2:如果Backup服务器端更改了SSH的默认密码,那这个数据该如何?1.本地同步
1.安装rsync
2.Rsync -av 源 ⽬标地址
3.如果源⽬录不以/结尾,整个⽬录同步包含⽬录⽂件,带斜杠,只同步⽬录下的⽂件
4.-R保留⽬录的相对路径,也会携带⽬录
5.同步的内容 ⽂件的新增 修改,删除(--delete) 属性(时间,权限)
2.远程同步
1.2台主机都⽀持rsync的服务
4、rsync作为系统服务
默认情况下,rsync只是作为⼀个命令来进⾏使⽤的(ps在查询进程时,找不到对应的服
务),但是rsync提供了⼀种作为系统服务的实现⽅式。
Linux系统服务的思路:
# rsync -e "ssh -p 10086" -av rsync.txt root@10.1.1.100:/root
2. rsync -ac 源 ⽤户@主机地址
2. 获取数据pull 拉取,发送数据push推送数据对外提供服务——>端⼝监听——>==启动服务==——>启动脚本——>配置⽂件
第⼀步:启动rsyncd服务(CentOS6中没有,CentOS7中有这个服务)
# systemctl start rsyncd
如果企业中使⽤到操作系统为CentOS6版本,则没有启动脚本。必须求帮助:
# man rsync
# rsync --help
Use "rsync --daemon --help" to see the daemon-mode command-line options.
CentOS6:rsync作为系统服务
# touch /etc/rsyncd.conf
# rsync --daemon
# ps -ef|grep rsync
# netstat -tunlp |grep rsync => -t tcp -u udp
注:如果rsync作为系统服务单独运⾏,则其底层就不需要SSH服务了!
第⼆步:rsyncd服务的配置⽂件/etc/rsyncd.conf
# man 5 rsyncd.conf
编号
IP地址
主机名称
⻆⾊
1
10.1.1.10
code.itcast.cn
Code(MIS)
2
10.1.1.100
backup.itcast.cn
Backup(Backup)
三、任务解决⽅案(重点)
1、环境准备
第⼀步:关闭防⽕墙与SELinux
第⼆步:更改主机名称
第三步:更改IP地址(静态IP)
# systemctl stop firewalld
# systemctl disable firewalld
# setenforce 0
# vim /etc/selinux/config
SELINUX=disabled
# hostnamectl set-hostname code.itcast.cn
# hostnamectl set-hostname backup.itcast.cn
# su# vim /etc/sysconfig/network-scripts/ifcfg-ens33
TYPE="Ethernet"
BOOTPROTO="none"
IPADDR=10.1.1.10
NETMASK=255.255.255.0
GATEWAY=10.1.1.2
DNS1=8.8.8.8
DNS2=114.114.114.114
NAME="ens33"
UUID="a5bb176c-c05c-4bdb-8975-a4aafa2fc90u" => 更改UUID的后3位
DEVICE="ens33"
ONBOOT="yes"
# vim /etc/sysconfig/network-scripts/ifcfg-ens33
TYPE="Ethernet"
BOOTPROTO="none"
IPADDR=10.1.1.100
NETMASK=255.255.255.0
GATEWAY=10.1.1.2
DNS1=8.8.8.8
DNS2=114.114.114.114
NAME="ens33"
UUID="a5bb176c-c05c-4bdb-8975-a4aafa2fc56y" => 更改UUID的后3位
DEVICE="ens33"
ONBOOT="yes"
# systemctl restart network
第四步:关闭NetworkManager
# systemctl stop NetworkManager
# systemctl disable NetworkManager
第五步:配置YUM源
略第六步:时间同步
2、任务解决⽅案
==Code:10.1.1.10服务器==
第⼀步:准备代码⽂件
第⼆步:把rsync作为系统服务运⾏
==Backup:10.1.1.100==
第三步:创建备份⽬录
第四步:测试rsync是否可以连接到rsync服务
# ntpdate cn.ntp.org.cn
# mkdir /app/java_project -p
# mkdir /app/java_project/aa{1..3}
# touch /app/java_project/file{1..9}.java
# vim /etc/rsyncd.conf
[app]
path=/app/java_project
log file=/var/log/rsync.log
# systemctl start rsyncd
# ps -ef |grep rsync
# netstat -tnlp |grep rsync
# mkdir /backup/app1_java -p下载⽂件到本地
第五步:编写计划任务 + Shell的脚本⽂件,⾃动实现代码备份
① 编写计划任务
② 编写rsync_java.sh脚本程序
3、任务总结
Code代码服务器 => 10.1.1.10
/app/java_project
Backup备份服务器 => 10.1.1.100
Code:
① 准备代码
② 编写/etc/rsyncd.conf⽂件,定义同步代码⽬录
# rsync -a root@10.1.1.10::
app
-a:获取rsync服务对应的同步⽬录标签
# rsync -av root@10.1.1.10::app /backup/app1_java
# crontab -e
3 1 * * * /root/rsync_java.sh
# vim rsync_java.sh
#!/bin/bash
rsync -av root@10.1.1.10::app /backup/app1_java &>/dev/null
# chmod +x rsync_java.sh③ 启动rsyncd服务
Backup:
① 测试rsync是否可以连接到Code服务器上的rsyncd服务
② 创建备份⽬录
③ 编写计划任务,凌晨1点03去Code服务器同步代码
④ 编写rsync_java.sh⽂件,实现同步操作
rsycn
安装
Yum -y install rsync
Rsync 【选项】源⽂件 ⽬标⽬录
1.本地同步
rsync -av ~/abc/ /opt/
同步⽂件的内容,⽂件的属性 ⽂件的新增 修改 删除(--delete)
rsync -av /⽬录 /tmp。# 同步⽬录下的⽂件
rsync -av /⽬录/ /tmp/ #同步⽬录
rsyn c -avR 保存相对路径,其实也就是同步了⽬录2.远程同步
要求两台主机要应该安装rsync服务
⽤法和本地同步相同
rsync -av root@192.168.71.135:/opt/ /tmp/ 拉取 pull
rsync -av /tmp/ root@192.168.71.135:/tmp. push 推送
需要输⼊密码,需要免密,这个需要的密码也是使⽤sssh服务验证,所以,直接ssh免密
设置好之后就直接⽀持rsync
3.同步服务器的设置
启动服务
systemctl start rsyncd
修改配置⽂件
vim /etc/rsyncd.conf
[abc]
path=/app/javaproject/
Log file=/var/log/rsync.log
重启rsync服务
systemctl restart rsyncd在另⼀台主机上拉取rsync服务中的项⽬
测试是否能够检测到项⽬ 检测到配置的abc
Rsync -a root@192.168.71.135::
abc
Rsync -av 源。⽬标⽬录
⾃动化推送拉取⽂件
没30s⾃动推送四、RSYNC课程扩展
1、给RSYNC服务添加密码
Code服务器:
① 打开/etc/rsyncd.conf配置⽂件
② 在/etc⽬录下创建rsyncd.secrets⽂件
③ 更改密码⽂件权限为600
④ 重启rsyncd服务
Backup备份服务器:
# vim /etc/rsyncd.conf
[app]
path=/app/java_project
log file=/var/log/rsync.log
auth users = user1,user2 => ⽤户名
secrets file = /etc/rsyncd.secrets => 密码⽂件
# vim /etc/rsyncd.secrets
user1:123 => 设置密码,⽤户名:密码
user2:123
# chmod 600 /etc/rsyncd.secrets
# systemctl restart rsyncd
# rsync -av user1@10.1.1.10::app ./
Password:123
2、RSYNC集合INOTIFY⼯具实现代码实时同步(重点)
第⼀步:直接安装inotify-tools
yum -y install inotify-tools
监听指定⽬录,⼀旦⽬录发上修改,就执⾏指定的指令
第⼆步:编写inotify.sh
# tar xf inotify-tools-3.13.tar.gz -C /usr/local/
# cd /usr/local/inotify-tools-3.14
# ./configure
# make
# make install
安装完后,就会产⽣下⾯两个命令
/usr/bin/inotifywait 等待
/usr/bin/inotifywatch 看守
/usr/bin/inotifywait
-m : ⼀直监控某个⽬录,create、delete、modify等⾏为
-r : 递归,不仅仅监控⽬录还要监控⽬录下的⽂件
-q : 获取操作信息,但是不输出
-e : 哪些⾏为需要被监控,modify,delete,create,attrib,move
modify: ⽂件被修改
delete: ⽂件被删除
create: ⽂件被创建
attrib: ⽂件属性被修改
move: ⽂件被移动
# vim inotify.sh
#!/bin/bashinotifywait -mrq -e modify,delete,create,attrib,move
/app/java_project |while read events
do
rsync -av --delete /app/java_project/
root@10.1.1.100:/backup/app1_java
echo "`date +%F\ %T`出现事件$events" >> /var/log/rsync.log 2>&1
done
我对/app/java_project做了两件事
① 在⽬录下创建了⼀个file9.java => create
② 在⽬录下删除了⼀个file5.java => delete
create,delete => while => 执⾏两次
create
rsync数据同步
delete
rsync数据同步
/usr/local/bin/inotifywait -mrq -e modify,delete,create,attrib,move
第三步:添加可执⾏权限
# chmod +x inotify.sh
第四步:让inotify.sh⽂件⼀直执⾏下去
# nohup ./inotify.sh &
& : 让inotify.sh在计算机后台运⾏,可以使⽤jobs命令查看,kill %编号结束,当我们退出
终端时,这个执⾏会⾃动结束
nohup : 让程序⼀直在后台运⾏,即使我们关闭了终端
扩展:如何查看rsync.log⽇志⽂件
# cat /var/log/rsync.log
声明:
本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:
https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/935580
推荐阅读
article
node
.
js
基于vue的
寻亲
互联网
平台
—
计算机
毕业设计
源码98418...
该
平台
采用的数据库是Mysql,Vue框架,使用Java技术开发。在设计过程中,充分保证了系统代码的良好可读性、实用性、...
赞
踩
article
Asp
.
Net
WebApi
核心
对象
解析(一)...
生活需要自己慢慢去体验和思考,对于知识也是如此。匆匆忙忙的生活,让人不知道自己一天到晚都在干些什么,似乎每天都在忙,但又...
赞
踩
article
electron
+
vue
3 自定义
窗口
:移动,缩放,置顶_
vue
windows
桌面置顶浮窗...
preload.jsCustomWindow.jsVUEmain.js 注册指令directives 自定义指令inde...
赞
踩
article
API
接口
漏洞
利用
及防御_api
接口
未
授权
访问
漏洞
...
API
(Application Programming Interface,应用程序编程
接口
)是不同软件系统之间进行数据...
赞
踩
article
一个
git
拉取
代码
并发布
服务器
的
shell
脚本
_
shell
脚本
拉取
代码
...
【
代码
】一个
git
拉取
代码
并发布
服务器
的
shell
脚本
。_
shell
脚本
拉取
代码
shell
脚本
拉取
代码
...
赞
踩
article
Xilinx
原语
详解之
IBUFDS
&
OBUFDS
...
IBUFDS
、
OBUFDS
、I
OBUFDS
是xilinx用于单端信号与差分信号相互转换的器件。_ibufdsibufds...
赞
踩
article
基于
YOLOv5
的
疲劳
驾驶
预警系统
:保障行车安全的创新技术_
yolo
疲劳
检测...
python深度学习基于
YOLOv5
的
疲劳
驾驶
预警系统
(Python源码+
疲劳
检测数据集+远程部署安装)项目源码请私信,...
赞
踩
article
2024年【
IAST
安全
左移
最佳
工具】
_
雳鉴
iast
...
IAST
将手动
安全
测试变成了自动化。
_
雳鉴
iast
雳鉴
iast
...
赞
踩
article
五、
决策树
与
随机
森林
实战_
决策树
和
随机
森林
方法
在
硕士
研究生
招生调剂管理中
的
应用...
一、
决策树
的
评价二、
决策树
的
过拟合
决策树
过拟合主要有两种处理方法:1.剪枝,2.
随机
森林
。剪枝分为预剪枝和后剪枝。预剪枝...
赞
踩
article
问题解决|
docker
出现Error
response
from
daemon
:
driver
fa...
主要是因为在启动
docker
容器的时候或做
docker
配置的时候,还对防火墙设置重新启动等配置,这样会清除
docker
的...
赞
踩
article
力扣
刷题前必学(
Java
刷题
常用
数据结构
及其
方法
)_
java
力扣
常用
数据结构
...
力扣
刷题前必学(
Java
刷题
常用
数据结构
及其
方法
)_
java
力扣
常用
数据结构
java
力扣
常用
数据结构
...
赞
踩
article
【
机器人
学】5-3.六自由度
机器人
轨迹
规划
-
笛卡尔
空间
- 直线与圆弧
规划
【附
MATLAB
代码】...
笛卡尔
空间
的路径
规划
与其说是一个运动学问题,倒不如说是一个几何问题。比如
笛卡尔
空间
的直线
规划
,给定起点A和终点B,连接A...
赞
踩
article
【
python
】在【
机器
学习
】与【
数据挖掘
】中的
应用
:从基础到【AI大
模型
】_
python
大
模型
...
Python在数据科学和
机器
学习
中的广泛
应用
,得益于其强大的库和工具。通过这些库和工具,数据科学家和工程师可以高效地进行...
赞
踩
article
tpcc
mysql
下载
_
TPCC
安装和压测
数据库
数据表创建生成...
下载
TPCC
-
mysql
[root@cnbugs1 ~]# git clone https://github.com/P...
赞
踩
article
Git
使用教程和GIT命令详细版_
git
reset
--
hard
后 执行命令...
配置信息通过
git
init命令把这个目录变成
Git
可以管理的仓库$
git
init。_
git
reset
--
hard
...
赞
踩
article
[
BTS
]
Adapter
Pack
调用
SAP
RFC
接口时间格式出错
解决办法
...
2009年4月18日14:44:29 错误信息如下 事件类型: 警告事件来源: BizTalk Server 2006...
赞
踩
article
Vue如何 使用
socket
.
io
实现
聊天室
功能?_
vue
-
socket
1
对
1
聊天室
...
好了,现在你已经掌握了
socket
.
io
的基本用法,接下来就让我们一起来看看在 Vue.js 组件中是如何使用 Sock...
赞
踩
article
【Git】使用
git
cherry
-
pick
时出现冲突解决实例_
encountered
confli...
cherry
pick
作用:把A分支的
commit
同步更新(提交)到B分支使用切换到B分支,执行下面语句
git
cher...
赞
踩
article
keil5
“Target ‘*‘
uses
ARM
-
Compiler
‘Default Compil...
由于再keil 5.37以后不再默认安装
Compiler
Verdion 5编译器,于是之前基于
Compiler
Ver...
赞
踩
article
电子地图
是
利用计算机
,
电子地图
制图
的运用与
发展
...
摘要:
电子地图
制图
是在信息革命的大背景下,地图学与计算机科学紧密结合的产物。它利用先进的信息技术极大地拓展了地图
制图
的方...
赞
踩
相关标签
node.js
vue.js
课程设计
spring boot
前端
后端
django
测试
json
electron
javascript
安全
网络
microsoft
git
服务器
elasticsearch
fpga开发
YOLO
深度学习
人工智能
疲劳驾驶
疲劳驾驶检测系统
计算机视觉
安全驾驶