rsync+inotify实时同步备份数据

rsync同步

rsync+inotify实时同步备份数据

软件简介:

rsync命令简介:

rsync命令是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件。
rsync使用所谓的“rsync算法”来使本地和远程两个主机之间的文件达到同步,这个
算法只传送两个文件的不同部分,而不是每次都整份传送,因此速度相当快。 rsync
是一个功能非常强大的工具,其命令也有很多功能特色选项,
来自: rsync命令

rsync [OPTION] SRC [USER@]HOST::DEST
rsync命令的选项:
  -a, archive 存档模式,等同于-rlptgoD (no -H,-A,-X)
  -u, update 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件,不覆盖更新的文件。
  -z, compress 压缩传送
  -R, relative 使用相对路径信息。
   –timeout=time ip超时时间,单位为秒。
  –delete 删除那些DST中SRC没有的文件。

Inotify命令简介:

Inotify是一种强大的、细粒度的、异步文件系统监控机制,它满足各种各样的文件监控需要,
可以监控文件系统的访问属性、读写属性、权限属性、删除创建、移动等操作,也就是可以监
控文件发生的一切变化。
来自: inotifywait命令

inotifywait  [OPTION…][ … ]
  -m 是要持续监视变化。
  -r 使用递归形式监视目录。
  -q 减少冗余信息,只打印出需要的信息。
  -e 指定要监视的事件列表。

关于rsync和Inotify更多详细信息可以查看命令手册;
也可以参考Linux命令大全,


1477615117373128.png

1. 安装配置rsync

1.1. yum安装软件rsync

# 软件安装
# 检查执行结果:rpm -aq rsync
yum install -y rsync

# 添加用户
# 检查执行结果:id rsync
useradd rsync -s /sbin/nologin  -M

# 创建目录并修改属主
# 检查执行结果:ll /mydata/rsync
mkdir -p /mydata/rsync
chown -R rsync: /mydata/rsync

1.2. rsync配置

cp /etc/rsyncd.conf{,.bak}
cat <<EOF > /etc/rsyncd.conf
# /etc/rsyncd: configuration file for rsync daemon mode

uid = rsync
gid = rsync

use chroot = no
max connections = 100
pid file = /var/run/rsyncd.pid
transfer logging = yes
log file = /var/log/rsyncd.log
exclude = lost+found/
timeout = 900
ignore nonreadable = yes
dont compress   = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2

[work]
      path = /mydata/rsync
      ignore errors
      read only = false
      list = false
      hosts allow = 10.10.20.0/24
      hosts deny = 0.0.0.0/0
      auth users = rsync_backup
      secrets file = /etc/rsynd.passwd

EOF

1.3. 虚拟用户secrets file

echo "rsync_backup:123456" > /etc/rsynd.passwd
chmod 600 /etc/rsynd.passwd

1.4. 启动rsync服务

systemctl start rsyncd

↑↑↑↑↑ On IP 10.10.20.79 ↑↑↑↑↑


↓↓↓↓↓ On IP 10.10.20.71 ↓↓↓↓↓↓

1.5. 测试rsync服务的同步功能

# 创建同步账户密码文件,仅需要密码,无须用户名
echo '123456' > /etc/rsync.passwd
# 提权
chmod 600 /etc/rsync.passwd
# 创建同步目录和测试文件
mkdir /mydata/rsync
echo 'just a test from IP 10.10.20.71' > /mydata/rsync/test

rsync -avz --password-file=/etc/rsync.passwd /mydata/rsync/ rsync_backup@10.10.20.79::work

2. 安装配置inotify

2.1. 下载软件

# 从网上下载程序,要求安装git
git clone https://github.com/rvoicilas/inotify-tools.git  /mydata/inotify-tools.git
# 编译安装inotify-tools
cd /mydata/inotify-tools.git
./autogen.sh 
# 编译三部曲
./configure --prefix=/usr/local/inotify
make && make install

2.2. 直接上脚本:

cat <<'EOF' > ~/bin/inotify.sh
#!/usr/bin/env bash
# -*- coding: utf-8 -*-
#
# Author: jacky18676887374@aliyun.com QQ 18676887374
# date: 20161027-10:05:20
# Vervion: 0.0.1
# Synopsis: COMAND
# 
# inotifywait COMMAND
Inotify="/usr/local/inotify/bin/inotifywait"
# inotifywait OPTION
Option_I='-mrq -e move,modify,delete,create,attrib'
# rsync OPTION
Option_R='-auz --delete --timeout=100  --password-file=/etc/rsync.passwd'
# rsync DEST
Dest='rsync_backup@10.10.20.79::work'
# backup file, inotify file; rsync SRC
Src="/mydata/rsync/"
#
########## judge ##########
if [ ! -e "$Src" ] \
|| [ ! -e "${Option_R##*=}" ] \
|| [ ! -e "${Inotify}" ] \
|| [ ! -e "/usr/bin/rsync" ];then
    echo "Check File and Folder"
    exit 9
fi
########## main ##########
$Inotify ${Option_I} $Src | while read file
    do
        rsync ${Option_R} $Src $Dest &> /dev/null
    done
exit 0
EOF

2.3. 修改执行权限并后台执行

chmod u+x ~/bin/inotify.sh
~/bin/inotify.sh &

原创文章,作者:昭其,如若转载,请注明出处:http://www.178linux.com/55125

(1)
昭其昭其
上一篇 2016-10-28 08:36
下一篇 2016-10-28 09:07

相关推荐

  • 马哥教育网络班21期-第四周课程练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 cp -a /etc/skel/ /home/tuser1 chmod -R 700 /home/tuser1/  2、编辑/etc/group文件,添加组hadoop。 echo "hadoop:x:2…

    Linux干货 2016-08-05
  • linux文件管理及bash的基本特性

    一、常用的文件和目录管理命令1、pwd命令:用来显示当前的工作目录语法格式:直接输入pwd回车显示当前的工作目录示例:用pwd命令显示当前的工作目录[root@suyiwen ~]# pwd/root2、mkdir命令:用来创建目录文件语法格式:mkdir [OPTION]… DIRECTORY…常用option:-m,用来指定目录的…

    Linux干货 2018-03-11
  • ​iptables简单介绍

    iptables简单介绍 什么是防火墙? 防火墙是工作在主机或网络边缘,能够对其所匹配到的报文根据事先定义好的规则作出相应处理的组件,可以是软件,也可以是硬件,还能软硬结合实现。 UNIX/Linux中对防火墙的实现 早期在openBSD中通过内核中的ipfw实现简单的数据报过滤功能、后来在Linux 2.2内核中使用ipchains来取代,意为链、后来在L…

    Linux干货 2016-03-31
  • linux进程和计划任务

    内核的功用:进程管理、文件系统、网络功能、内存管理、驱动程序、 安全功能等 进程管理:     系统优先级:数字越小,优先级越高    实时优先级: 99-0,值最大优先级最高    nice值:-20 到19 ,对应系统优先级100-139或99 Linux 内核:抢占式多任务  &nb…

    Linux干货 2017-03-23
  • Linux程序包管理之RPM

    Linux程序包管理之RPM RPM概念 rpm是什么 RPM 是Ret Hat Package Manager(RPM软件包管理器)的缩写,遵循GPL协议,可以运行在各种Linux上,公认的行业标准。 rpm干什么 对于终端用户来说 简化了Linux系统的安装、卸装、更新和升级的过程,用命令完成 对于开发者来说 RPM允许把软件编码包装成源代码和程序包提供…

    Linux干货 2016-11-22
  • 一起学DHCP系列(一)开篇、概述

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://jeffyyko.blog.51cto.com/28563/162108     从本节开始,我们将开始讨论有关DHCP服务器的相关问题,从易到难一步步理解DHCP服务。还是一样,在…

    Linux干货 2015-03-25