centos7只rsync+inotify
环境:
操作系统:centos7.4
192.168.1.238 客户端
192.168.1.239 服务端
环境准备:
1、安装以下安装包lrzsz是xshell上传下载的安装包,可以忽略。
yum install -y lrzsz gcc wget gcc-c++ vim
2、关闭firewall防火墙,开机禁止启动。永久关闭selinux。如果有iptables防火墙可以允许873端口。
服务端
1、安装rsync
yum install -y rsync
2、更改配置文件
vim /etc/rsyncd.conf
#工作中指定用户(可以不指定为0)
uid =
gid =
#相当于黑洞.出错定位
use chroot = no
##有多少个客户端同时传文件
max connections =
##超时时间
timeout =
##进程号文件
pid ifle = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
##日志文件
log file = /var/log/rsyncd.log
##模块开始(这个模块就是待会儿对端写脚本的里面一个参数的名称)
[msone]
##需要同步的目录(准确的说是同步过来后放到哪里的目录路径)
path = /data/www
##表示出现错误忽略错误
ignore errors
##表示网络权限可写(本地控制真正可写)(亲测这里写false报错)
read only = no
##这里设置IP或让不让同步
list = false
#允许的ip或者ip段
hosts allow = 192.168.1.238
##拒绝,以下表示都不拒绝
hosts deny = 0.0.0.0/
##认证用户
auth users = rsynclsl
##用户名和密码存放文件
secrets file = /etc/rsync.secrets
rsyncd.conf
3、添加同步需要用的用户名和密码
#useradd -s /sbin/nologin rsynclsl
#passwd rsynclsl
4、创建认证文件
vim /etc/rsync.secrets
文件里面添加如下内容(格式为用户名:密码):
rsynclsl:123456
5、为了安全起见给这个文件设置600权限。
6、启动服务
#rsync --daemon
7、创建需要过来存放的目录
mkdir -p /data/www
需要www这个目录其它用户可以写的权限
chmod 765 www
8、如果需要添加开机启动请看另外一篇博客http://www.cnblogs.com/lei0213/p/8595030.html
客户端
1、查看当前系统是否支持inotify,这三个文件具体做什么的可以自行百度
2、安装rsync和inotify(rsync只安装不启动不配置)
yum install -y rsync
3、inotify是一种强大的、细粒度的、异步的文件系统事件控制机制。linux内核从2.6.13起,加入了inotify支持,通过inotify可以监控文件系统中添加、删除、修改、移动等各种事件,利用这个内核接口,第三方软件就可以监控文件系统下文件的各种变化情况,而inotify-tools正是实施监控的软件。
#wget http://github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz
#tar zxf inotify-tools-3.14.tar.gz
#cd inotify-tools-3.14
#./configure --prefix=/usr/local/include/
# make && make install
官网:https://sourceforge.net/projects/inotify-tools/
4、最最最最最最重要的是要写这个脚本,让它自动去检测我们制定的目录下文件发生的变化,然后再执行rsync的命令把它同步到我们的服务器端去。
#touch inotify.sh
#chmod 755 inotify.sh
#vim inotify.sh
#!/bin/bash
#chkconfig:
host=192.168.1.239 #server的ip(备份服务器)
src=/data/www #所要监控的备份目录(此处可以自定义,但是要保证存在)
des=msone #自定义的模块名,需要与client端定义的一致
password=/etc/rsync.password #密码文件
user=rsynclsl #用户名(一个实际存在的账号)
inotify=/usr/local/include/ #inotify的安装目录 ${inotify}/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f%e' -e modify,delete,create,attrib $src \
| while read files
do
rsync -avzP --delete --timeout= --password-file=${password} $src $user@$host::$des
echo "${files} was rsynced" >>/tmp/rsync.log >&
done
inotify.sh
5、创建/etc/rsync.password文件(整个文件需要600的权限和服务端rsync同步用户的密码,这里是服务器端rsynclsl用户的密码)
vim /etc/rsync.password
6、执行该脚本
#./inotify.sh
7、如果需要添加开机启动请看另外一篇博客http://www.cnblogs.com/lei0213/p/8595030.html
8、如果不确定脚本能不能用,可以先不用执行脚本,先使用下面的rsync命令同步一下看看配置有没有问题。
rsync -avH --port=873 --delete /data/www/ rsynclsl@192.168.1.239::msone --password-file=/etc/rsync.password
测试
1、服务器客户端全部关闭selinux和firewalld及iptables(或者允许873端口通过)
2、服务端启动rsync服务即可(进入/data/www准备刷新)
3、客户端启动脚本。
4、在客户端进入客户端的/data/www目录下建立文件,更改内容。
5、服务器端刷新
6、客户端会把www整个目录传到服务器端的/data/www下,等于在/data/www/下又出现了一个www目录。
centos7只rsync+inotify的更多相关文章
- CentOS7之Rsync+Inotify架构实现实时同步文件和文件夹
简介:rsync是用来同步文件和文件夹的,inotify是用来实现监听变动而自动同步的 OS:Centos7.3 服务器端:172.16.13.157 客 户 端 :172.16.13.156 目 ...
- centos7配置rsync+inotify数据实时共享
关于centos7版本上面搭建rsync服务并且实现实时同步之前一直是在6版本上面搭建rsync服务,在7版本上面折腾了半天.此处总结下inotify下载地址:http://github.com/do ...
- centos7下rsync+inotify脚本实现文件同步,.NET CORE客户端文件更新后自动重启服务
源服务器IP:192.168.8.51 目标服务器IP:192.168.8.79 安装前源服务器及目标服务器均需关闭FIREWALLD\SELINUX防火墙 sestatus | grep statu ...
- CentOS7 Rsync服务搭建-Rsync+Inotify架构实现实时同步
一.rsync 概念 1.rsyncrsync是类unix/linux系统下的数据镜像备份工具.使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,或者与其他SSH.rsync主机同 ...
- CentOS7安装和配置rsync+inotify
(1)rsync介绍 1.rsync介绍 开源,实现全量及增量的本地或远程数据同步备份工具 2.工作场景: 存储实时备份:rsync+inotify 定时备份:rsync+crond 3.rsync工 ...
- rsync+inotify实现全网自动化数据备份-技术流ken
rsync简介 “rsync是linux系统下的数据镜像备份工具.使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,或者与其他SSH.rsync主机同步” rsync的功能和特点 ...
- rsync简介与rsync+inotify配置实时同步数据
rsync简介 rsync是linux系统下的数据镜像备份工具.使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,或者与其他SSH.rsync主机同步. rsync特性 rsync ...
- rsync+inotify实现数据实时同步
rsync rsync是linux系统下的数据镜像备份工具.支持远程同步,本地复制,或者与其他SSH.rsync主机同步. 优点: 1).可以镜像保存整个目录树和文件系统.保存源目录整个目录树和文件系 ...
- 通过rsync+inotify实现数据实时备份
rsync的优点与不足 与传统的cp,scp,tar,备份方式相比,rsync具有安全性高备份迅速支持增量备份的优点,可以满足对实时性要求不高的需求,例如定期备份文件服务器数据到远端服务器,但是,当数 ...
随机推荐
- Docker 更新镜像
docker镜像如下: 今天在运行的容器内使用 apt-get update 命令进行更新时,发下很多404错误. Err http://archive.ubuntu.com wily-updates ...
- Java开发笔记(六十五)集合:HashSet和TreeSet
对于相同类型的一组数据,虽然Java已经提供了数组加以表达,但是数组的结构实在太简单了,第一它无法直接添加新元素,第二它只能按照线性排列,故而数组用于基本的操作倒还凑合,若要用于复杂的处理就无法胜任了 ...
- Android安全–检测是否为Android模拟器
有时候需要检测是否在模拟器上运行还是在真机运行,话不多说.检测代码如下: package com.monkey.antiemulator; import java.io.File; import ja ...
- Java 学习笔记 网络编程 使用Socket传输文件 CS模式
Socket的简单认识 Socket是一种面向连接的通信协议,Socket应用程序是一种C/S(Client端/Server端)结构的应用程序 Socket是两台机器间通信的端点. Socket是连接 ...
- Java基础:Object类中的equals与hashCode方法
前言 这个系列的文章主要用来记录我在学习和复习Java基础知识的过程中遇到的一些有趣好玩的知识点,希望大家也喜欢. 一切皆对象 对于软件工程来说面向对象编程有一套完整的解决方案:OOA.OOD.O ...
- vue+vuecli+webapck2实现多页面应用
准备工作 在本地用vue-cli新建一个项目,首先安装vue-cil,命令: npm install -g vue-cli 新建一个vue项目,创建一个基于"webpack"的项目 ...
- 博弈论进阶之Every-SG
Every-SG 给定一张无向图,上面有一些棋子,两个顶尖聪明的人在做游戏,每人每次必须将可以移动的棋子进行移动,不能移动的人输 博弈分析 题目中的要求实际是"不论前面输与否,只要最后一个棋 ...
- Ambari Agent 源码分析
一.ambari-agent 启动方式 Ambari-Agent的启动脚本为/etc/init.d/ambari-agent.该脚本主要实现了start,stop,status,restart,res ...
- 41.Odoo产品分析 (四) – 工具板块(10) – 问卷(1)
查看Odoo产品分析系列--目录 在该模块下,可以创建问卷,收集答案,打印统计. 安装"问卷"模块,首页显示当前各个阶段中的问卷: 打开"开发者模式",能对 ...
- python集合使用范例的代码
在代码过程中中,将代码过程中比较好的代码段珍藏起来,如下的代码是关于python集合使用范例的代码,希望能对大伙有用. # sets are unordered collections of uniq ...