当前位置: 首页 > news >正文

企业怎样建网站中关村标准化协会

企业怎样建网站,中关村标准化协会,企业实缴公示在什么网站做,做旅游网站的工作流程图文章目录 Linux系统下数据同步服务RSYNC一、RSYNC概述1、什么是rsyncrsync的好姐妹数据同步过程 2、rsync特点3、rsync与scp的区别 二、RSYNC的使用1、基本语法2、本地文件同步3、远程文件同步思考:4、rsync作为系统服务Linux系统服务的思路: 三、任务解…

文章目录

  • 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---
http://www.qdjiajiao.com/news/4425.html

相关文章:

  • 装修设计的网站注册公司网站
  • 网站版式有哪几种百度公司的发展历程
  • 泰安网络平台镇江关键字优化公司
  • 怎样去权重高的网站做外链今日新闻事件
  • 中新生态城建设局门户网站怎么写网站
  • 宁波住房建设网站管理系统
  • 网站支付怎么做安全吗上首页seo
  • 微信网站制作系统网上接单平台有哪些
  • 网站栏目做树形结构图自己可以创建网站吗
  • 平台网站开发的税率我想接app纯注册推广单
  • 做网站是什么推广平台软件有哪些
  • wordpress网页特效seo销售话术开场白
  • 苏州seo网络推广网络优化培训要多少钱
  • 哪些网站做农产品电子商务百度指数的搜索指数
  • 扬中企业网站优化哪家好如何推广自己成为网红
  • 网站底部连接怎么做企业网站怎么注册
  • 提升审美网站产品推广软文500字
  • 2345浏览器网页版入口官网站长之家seo查询官方网站
  • 绵阳市公司网站建设全网营销系统1700元真实吗
  • wordpress 网站重置关键词调词平台
  • wordpress本地时间网站页面优化方法
  • 可以做家装设计的网站搜索关键词查询工具
  • 网站收录慢批量关键词调排名软件
  • 网站建设只有一个空间吗口碑营销的方法
  • 做h5那个网站模板好app关键词推广
  • 湖南网站建设的公司seo数据分析
  • b2c网站制作生成关键词的软件
  • 昆明的房产网站建设网络营销网站设计
  • wordpress站长主题游戏推广员如何推广引流
  • 潍坊网站建设wfyckj怎样做百度推广网页