linux系统服务学习(四)Linux系统下数据同步服务RSYNC
文章目录
- Linux系统下数据同步服务RSYNC
- 一、RSYNC概述
- 1、什么是rsync
- rsync的好姐妹
- 数据同步过程
- 2、rsync特点
- 3、rsync与scp的区别
- 二、RSYNC的使用
- 1、基本语法
- 2、本地文件同步
- 3、远程文件同步
- 思考:
- 4、rsync作为系统服务
- Linux系统服务的思路:
- 三、任务解决方案(重点)
- 1、环境准备
- 第一步:关闭防火墙与SELinux
- 第二步:更改主机名称
- 第三步:更改IP地址(静态IP)
- 第四步:关闭NetworkManager
- 第五步:配置YUM源
- 第六步:时间同步
- 2、任务解决方案
- 第一步:准备代码文件
- 第二步:把rsync作为系统服务运行
- 第三步:创建备份目录
- 第四步:测试rsync是否可以连接到rsync服务
- 第五步:编写计划任务 + Shell的脚本文件,自动实现代码备份
- 3、任务总结
- 四、RSYNC课程扩展
- 1、给RSYNC服务添加密码
- 2、RSYNC集合INOTIFY工具实现代码实时同步(重点)
- 第一步:在Code服务器端安装inotify-tools工具(监控器)
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能力更强
① 支持增量备份
② 数据同步时保持文件的原有属性
二、RSYNC的使用
1、基本语法
# man rsync
NAMErsync — a fast, versatile, remote (and local) file-copying tool//一种快速、通用、远程(和本地)的文件复制工具
SYNOPSIS//本地文件同步Local:rsync [OPTION...] SRC... [DEST]//远程文件同步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属性
PUSH:推,相当于上传;PULL:拉,相当于下载
2、本地文件同步
本地文件同步简单理解就是把文件从一个位置(同步=>拷贝)到另外一个位置(类似cp)
案例:/dir1、/dir2与/dir3,/dir1中创建三个文件file1、file2、file3,使用rsync本地同步
# mkdir /dir1# mkdir /dir2# mkdir /dir3# touch /dir1/file{1..3}# rsync -av /dir1/ /dir2 => 把/dir1目录中的所有文件拷贝到/dir2目录中# rsync -av /dir1 /dir3 => 把/dir1目录整体同步到/dir3目录中
案例:rsync -R选项的应用(保留相对路径)
# rsync -avR /dir1/ /dir2
案例:rsync --delete(删除目标目录里多余的文件)
/dir1 === /dir2file1、file2 file1、file2、file3rsync --delete同步后,会自动删除file3文件。(让dir1与dir2目录中的文件高度一致)# rsync -av --delete /dir1/ /dir2
3、远程文件同步
Push:上传文件到远程服务器端
# rsync -av 本地文件或目录 远程用户名@远程服务器的IP地址:目标路径
案例:把linux.txt文档传输到远程服务器端(192.168.1.12)
# rsync -av linux.txt
案例:把shop文件夹传输到远程服务器端(192.168.1.12)
# rsync -av shop root@192.168.1.12:/root
Pull:下载文件到本地服务器端
# rsync -av 远程用户名@远程服务器的IP:目标文件或目录 本地存储位置
案例:把远程服务器(192.168.1.12)的/etc/hosts文件下载到本地
# rsync -av root@192.168.1.12:/etc/hosts ./
案例:把远程服务器(192.168.1.12)的/shop文件夹下载到本地
# rsync -av root@192.168.1.12:/shop ./
# rsync -av -e "ssh -p 2222" root@121.43.54.39:/root/xxx.txt
思考:
问题1:rsync远程同步数据时,默认情况下为什么需要密码?如果不想要密码同步怎么实现?
rsync在远程同步时,之所以要输入密码的主要原因在于其底层还是基于SSH服务的。SSH有两种认证方式,如果没有配置免密则默认使用用户名+密码的认证方式。
不想要密码同步,可以考虑使用SSH免密操作。
Code => Backup
Code:
# ssh-keygen -t rsa -P ""
# ssh-copy-id root@192.168.1.12
问题2:如果Backup服务器端更改了SSH的默认端口,那这个数据该如何?
# rsync -e "ssh -p 10086" -av rsync.txt root@192.168.1.12:/root
4、rsync作为系统服务
默认情况下,rsync只是作为一个命令来进行使用的(ps在查询进程时,找不到对应的服务),但是rsync提供了一种作为系统服务的实现方式。
Linux系统服务的思路:
对外提供服务——>端口监听——>启动服务——>启动脚本——>配置文件
第一步:启动rsyncd服务(CentOS6中没有,CentOS7中有这个服务)
#端口监听 natstat naput | grep 2222
# systemctl start rsyncd
#/usr/bin/rsync --daemon 后台启动
第二步:rsyncd服务的配置文件/etc/rsyncd.conf
# man 5 rsyncd.conf
三、任务解决方案(重点)
1、环境准备
编号 IP地址 主机名称 角色
1 192.168.1.11 代码服务器 hd1 Code(MIS)
2 192.168.1.12 hd2 Backup(Backup)
第一步:关闭防火墙与SELinux
# systemctl stop firewalld
# systemctl disable firewalld# setenforce 0
# vim /etc/selinux/config
SELINUX=disabled
第二步:更改主机名称
# hostnamectl set-hostname hd1 #在第一台服务器上
# hostnamectl set-hostname hd2 #在第二胎服务器上
第三步:更改IP地址(静态IP)
# vim /etc/sysconfig/network-scripts/ifcfg-ens33
TYPE="Ethernet"
BOOTPROTO="none"
IPADDR=192.168.1.11
NETMASK=255.255.255.0
GATEWAY=192.168.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=192.168.1.12
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源
略
第六步:时间同步
# ntpdate cn.ntp.org.cn
2、任务解决方案
Code:192.168.1.11服务器
第一步:准备代码文件
# mkdir /app/java_project -p
# mkdir /app/java_project/aa{1..3}
# touch /app/java_project/file{1..9}.java
第二步:把rsync作为系统服务运行
# 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
切换到Backup:192.168.1.12
第三步:创建备份目录
# mkdir /backup/app1_java -p
第四步:测试rsync是否可以连接到rsync服务
# rsync -a root@192.168.1.11::app
-a:获取rsync服务对应的同步目录标签
下载文件到本地
# rsync -av root@192.168.1.11::app /backup/app1_java
两个:表示走的不是ssh协议
第五步:编写计划任务 + Shell的脚本文件,自动实现代码备份
① 编写计划任务
# crontab -e
3 1 * * * /root/rsync_java.sh
② 编写rsync_java.sh脚本程序
# vim rsync_java.sh
#!/bin/bash
rsync -av root@192.168.1.11::app /backup/app1_java &>/dev/null #表示错误重定向和正确重定向# chmod +x rsync_java.sh
3、任务总结
Code代码服务器 => 192.168.1.11 /app/java_project
Backup备份服务器 => 192.168.1.12
Code:
① 准备代码
② 编写/etc/rsyncd.conf文件,定义同步代码目录
③ 启动rsyncd服务
Backup:
① 测试rsync是否可以连接到Code服务器上的rsyncd服务
② 创建备份目录
③ 编写计划任务,凌晨1点03去Code服务器同步代码
④ 编写rsync_java.sh文件,实现同步操作
四、RSYNC课程扩展
1、给RSYNC服务添加密码
Code服务器:
① 打开/etc/rsyncd.conf配置文件
# vim /etc/rsyncd.conf
[app]
path=/app/java_project
log file=/var/log/rsync.log
auth users = user1,user2 => 用户名
secrets file = /etc/rsyncd.secrets => 密码文件
② 在/etc目录下创建rsyncd.secrets文件
# vim /etc/rsyncd.secrets
user1:123 => 设置密码,用户名:密码
user2:123
③ 更改密码文件权限为600
# chmod 600 /etc/rsyncd.secrets
④ 重启rsyncd服务
# systemctl restart rsyncd
Backup 192.168.1.12备份服务器:
# rsync -av user1@192.168.1.11::app ./
Password:123
避免人机交互的方式
[root@hd2 ~]# cat /etc/rsync_passwd #创建一个密码文件
123
[root@hd2 ~]# chmod 600 /etc/rsync_passwd #设置权限
[root@hd2 ~]# rsync -av user1@192.168.1.11::app /backup/app1_java/ --password-file=/etc/rsync_passwd #这是一行
2、RSYNC集合INOTIFY工具实现代码实时同步(重点)
说明一下,此实验最好在ssh免密的环境下实现
第一步:在Code服务器端安装inotify-tools工具(监控器)
源码安装需要的软件 # yum -y install gcc make zlib-devel pcre pcre-devel openssl-devel将inotify-tools-3.13.tar.gz包传到虚拟机中# tar xf inotify-tools-3.13.tar.gz -C /usr/local/# cd /usr/local/inotify-tools-3.14# ./configure# make # make install```安装完后,就会产生下面两个命令/usr/local/bin/inotifywait 等待/usr/local/bin/inotifywatch 看守/usr/local/bin/inotifywait-m : 一直监控某个目录,create、delete、modify等行为-r : 递归,不仅仅监控目录还要监控目录下的文件-q : 获取操作信息,但是不输出-e : 哪些行为需要被监控,modify,delete,create,attrib,movemodify: 文件被修改delete: 文件被删除create: 文件被创建attrib: 文件属性被修改move: 文件被移动#### 第二步:编写inotify.sh# vim inotify.sh#!/bin/bash/usr/local/bin/inotifywait -mrq -e modify,delete,create,attrib,move /app/java_project |while read eventsdorsync -av --delete /app/java_project/ root@192.168.1.12:/backup/app1_javaecho "`date +%F\ %T`出现事件$events" >> /var/log/rsync.log 2>&1done我对/app/java_project做了两件事① 在目录下创建了一个file9.java => create② 在目录下删除了一个file5.java => deletecreate,delete => while => 执行两次creatersync数据同步deletersync数据同步/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---
相关文章:
linux系统服务学习(四)Linux系统下数据同步服务RSYNC
文章目录 Linux系统下数据同步服务RSYNC一、RSYNC概述1、什么是rsyncrsync的好姐妹数据同步过程 2、rsync特点3、rsync与scp的区别 二、RSYNC的使用1、基本语法2、本地文件同步3、远程文件同步思考:4、rsync作为系统服务Linux系统服务的思路: 三、任务解…...

走进 Linux
一、开关机 开机: 开机会启动许多程序。他们在windows叫做“服务”(service),在Linux就叫做“守护进程”(daemon)开机成功后,它会显示一个文本登录界面, 这个界面就是我们经常看到的登录界面,在这个登录界…...
Docker高级——Docker Swarm集群和部署应用
创建 Swarm 集群 初始化管理节点 [rootk8s-master ~]# docker swarm init --advertise-addr 192.168.192.133 Swarm initialized: current node (vy95txqo3pglh478e4qew1h28) is now a manager.To add a worker to this swarm, run the following command:docker swarm join …...
【SA8295P 源码分析】74 - QNX secpol 安全策略文件配置详解 及 secpol.bin 编译过程分析
【SA8295P 源码分析】74 - QNX secpol 安全策略文件配置详解 及 secpol.bin 编译过程分析 一、secpol 的编译流程:编译生成 secpol.bin 打包在 ifs2_la.img 中二、QNX 开启 secpol 功能三、为新进程 创建 新的secpol 安全策略:以 vmm_service 为例四、secpol 配置示例,以 I2…...
Docker入门使用
用一个hello world的小例子来入门docker 在 Docker 容器中部署 Python Flask 的简单 Hello World 项目,需要遵循以下流程: 编写应用程序 首先,在本地计算机上编写一个简单的 PythonFlask 应用程序,例如: # hello.…...
在SAP上使用 LiquidUI Android 扫描条形码/QR 码
LiquidUI Android 可使用安卓移动设备的内置摄像头扫描条形码和二维码,为输入框填充数值。因此,无需附加任何第三方设备进行扫描。 LiquidUI Android 还提供了扫描功能,如 Accessible-Enter(俗称自动输入)和 Accessib…...

Maven - 全面解析 Maven BOM (Bill of Materials):打造高效依赖管理与模块化开发
文章目录 Whats BOMWhy Bom常見的官方BOMSpring Maven BOM dependencySpringBoot SpringCloud Maven BOM dependencyJBOSS Maven BOM dependencyRESTEasy Maven BOM dependencyJersey Maven BOM dependency How Bom定义BOM其他工程使用的方法 BOM VS POM What’s BOM BOM&…...

Lua脚本对比redis事务区别是什么
redis官方对于lua脚本的解释:Redis使用同一个Lua解释器来执行所有命令,同时,Redis保证以一种原子性的方式来执行脚本:当lua脚本在执行的时候,不会有其他脚本和命令同时执行,这种语义类似于 MULTI/EXEC。从别…...
ES安装问题汇总
max file descriptors [4096] for elasticsearch process is too low, increase to at least [65535] 问题描述 ES启动报错。其原因是ES需要的的最小max file descriptors为65535,我们设置的是4096,需要增大max file descriptors的值。 解决方案 调大…...

煜邦转债,华设转债,兴瑞转债,神通转债上市价格预测
煜邦转债 基本信息 转债名称:煜邦转债,评级:A,发行规模:4.10806亿元。 正股名称:煜邦电力,今日收盘价:8.82元,转股价格:10.12元。 当前转股价值 转债面值 / …...

R语言生存分析算法的简单组合
library(survival) library(randomForestSRC)# 生成模拟数据 set.seed(123) n <- 200 time <- rexp(n, rate 0.1) status <- rbinom(n, size 1, prob 0.7) var1 <- rnorm(n) var2 <- rnorm(n) var3 <- rnorm(n) data1 <- data.frame(time time, statu…...

Qt应用开发(基础篇)——滚屏区域基类 QAbstractScrollArea
一、前言 QAbstractScrollArea滚屏区域抽象类继承于QFrame,QFrame继承于QWidget,是QListview(列表浏览器)、QTableview(表格浏览器)、QTextEdit(文本编辑器)、QTextBrowser(文本浏览器)等所有需要滚屏区域部件的抽象基类。 框架类QFrame介绍 QAbstractSc…...

HTTPS安全通信
HTTPS,TLS/SSL Hyper Text Transfer Protocol over Secure Socket Layer,安全的超文本传输协议,网景公式设计了SSL(Secure Sockets Layer)协议用于对Http协议传输的数据进行加密,保证会话过程中的安全性。 使用TCP端口默认为443 TLS:(Transport Layer Security,传输层…...

C语言暑假刷题冲刺篇——day1
目录 一、选择题 二、编程题 🎈个人主页:库库的里昂 🎐CSDN新晋作者 🎉欢迎 👍点赞✍评论⭐收藏✨收录专栏:C语言每日一练 ✨其他专栏:代码小游戏C语言初阶🤝希望作者的文章能对你…...

trollcave靶场
配置 第一步:启动靶机时按下 shift 键, 进入以下界面 第二步:选择第二个选项,然后按下 e 键,进入编辑界面 将这里的ro修改为rw single init/bin/bash,然后按ctrlx,进入一个相当于控制台的界面…...
反馈式编译
一、 反馈式编译 简介 PGO,即Profile-Guided Optimizations,反馈式优化。PGO是编译器的又一优化技术,PGO与其它的一些优化技术/选项有一个明显的区别是:PGO优化是分三步完成的,是一个动态的优化过程。 反馈优化过…...

sql-libs靶场-----0x00、环境准备
文章目录 一、PhPstudy下载、安装二、Sqli-libs下载、搭建三、启用Sqli-libs phpstudy地址:https://www.xp.cn/ sqli-libs地址:https://github.com/Audi-1/sqli-labs 一、PhPstudy下载、安装 1、下载–解压–安装,安装完成如下图 2、更换php…...

一百四十九、Kettle——Linux上安装的kettle8.2创建共享资源库时遇到的问题(持续更新中)
一、目的 在kettle8.2在Linux上安装好可以启动界面、并且可以连接MySQL、Hive、ClickHouse等数据库后开始创建共享资源库,但是遇到了一些问题 二、Linux系统以及kettle版本 (一)Linux:CentOS 7 英文的图形化界面模式 &#…...
Mysql 建索引规范
索引规范 今天在建线上表的时候,做了一个varchar的索引,运维说varchar的索引会占用很大的内存。 于是 上网搜了一下建索引规范 一、建表规约 【强制】(1) 存储引擎必须使用InnoDB 解读:InnoDB支持事物、行级锁、并发…...

新基建助推数字经济,CosmosAI率先布局AI超算租赁新纪元
伦敦, 8月14日 - 在英国伦敦隆重的Raffles OWO举办的欧盟数字超算新时代战略合作签约仪式,CosmosAI、Infinite Money Fund与Internet Research Lab三方强强联手,达成了历史性的合作协议,共同迈向超算租赁新纪元。 这次跨界的合作昭示了全球…...

大数据学习栈记——Neo4j的安装与使用
本文介绍图数据库Neofj的安装与使用,操作系统:Ubuntu24.04,Neofj版本:2025.04.0。 Apt安装 Neofj可以进行官网安装:Neo4j Deployment Center - Graph Database & Analytics 我这里安装是添加软件源的方法 最新版…...
云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?
大家好,欢迎来到《云原生核心技术》系列的第七篇! 在上一篇,我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在,我们就像一个拥有了一块崭新数字土地的农场主,是时…...

【WiFi帧结构】
文章目录 帧结构MAC头部管理帧 帧结构 Wi-Fi的帧分为三部分组成:MAC头部frame bodyFCS,其中MAC是固定格式的,frame body是可变长度。 MAC头部有frame control,duration,address1,address2,addre…...
Xen Server服务器释放磁盘空间
disk.sh #!/bin/bashcd /run/sr-mount/e54f0646-ae11-0457-b64f-eba4673b824c # 全部虚拟机物理磁盘文件存储 a$(ls -l | awk {print $NF} | cut -d. -f1) # 使用中的虚拟机物理磁盘文件 b$(xe vm-disk-list --multiple | grep uuid | awk {print $NF})printf "%s\n"…...

搭建DNS域名解析服务器(正向解析资源文件)
正向解析资源文件 1)准备工作 服务端及客户端都关闭安全软件 [rootlocalhost ~]# systemctl stop firewalld [rootlocalhost ~]# setenforce 0 2)服务端安装软件:bind 1.配置yum源 [rootlocalhost ~]# cat /etc/yum.repos.d/base.repo [Base…...

解读《网络安全法》最新修订,把握网络安全新趋势
《网络安全法》自2017年施行以来,在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂,网络攻击、数据泄露等事件频发,现行法律已难以完全适应新的风险挑战。 2025年3月28日,国家网信办会同相关部门起草了《网络安全…...
LOOI机器人的技术实现解析:从手势识别到边缘检测
LOOI机器人作为一款创新的AI硬件产品,通过将智能手机转变为具有情感交互能力的桌面机器人,展示了前沿AI技术与传统硬件设计的完美结合。作为AI与玩具领域的专家,我将全面解析LOOI的技术实现架构,特别是其手势识别、物体识别和环境…...
在golang中如何将已安装的依赖降级处理,比如:将 go-ansible/v2@v2.2.0 更换为 go-ansible/@v1.1.7
在 Go 项目中降级 go-ansible 从 v2.2.0 到 v1.1.7 具体步骤: 第一步: 修改 go.mod 文件 // 原 v2 版本声明 require github.com/apenella/go-ansible/v2 v2.2.0 替换为: // 改为 v…...

leetcode73-矩阵置零
leetcode 73 思路 记录 0 元素的位置:遍历整个矩阵,找出所有值为 0 的元素,并将它们的坐标记录在数组zeroPosition中置零操作:遍历记录的所有 0 元素位置,将每个位置对应的行和列的所有元素置为 0 具体步骤 初始化…...

21-Oracle 23 ai-Automatic SQL Plan Management(SPM)
小伙伴们,有没有迁移数据库完毕后或是突然某一天在同一个实例上同样的SQL, 性能不一样了、业务反馈卡顿、业务超时等各种匪夷所思的现状。 于是SPM定位开始,OCM考试中SPM必考。 其他的AWR、ASH、SQLHC、SQLT、SQL profile等换作下一个话题…...