Home PC Games Linux Windows Database Network Programming Server Mobile  
  Home \ Server \ rsync + inotify to achieve real-time synchronization     - Build ASP.NET 5 development environment in Ubuntu (Server)

- MongoDB3.0.6 wiredtiger MMAPv1 (Database)

- Node.js v4.0.0 installation configuration on Ubuntu 14.04 / 15.04 (Linux)

- Linux port mapping system (routing and forwarding) (Server)

- Oracle ORA-01089 failure analysis (Database)

- Based shell: using read, the command-line script to achieve mass participation and input two integer calculation (Programming)

- Linux --- file descriptors and redirection (Linux)

- MongoDB learning Notes (2) basic connection example of -Nodejs and MongoDB (Database)

- Ubuntu prompt / lack of boot space solutions (Linux)

- Ease of use "Explain Shell" script to understand Shell command (Linux)

- Why everybody ought to know LLVM (Linux)

- How to Install Focuswriter 1.4.5 (Linux)

- Java Concurrency -volatile keywords (Programming)

- Linux Services Comments (Linux)

- JavaScript prototype and prototype chain and project combat (Programming)

- To install network scanning and packet sniffer tool Nmap 7.00 under ubuntu (Linux)

- Kali Linux virtualbox rc = Error 1908 workaround (Linux)

- Linux-based Heartbeat high availability configuration httpd service (Server)

- Package the Python script file into an executable file (Programming)

- Android application simulates the phone keypad (Programming)

  rsync + inotify to achieve real-time synchronization
  Add Date : 2018-11-21      
  Rsync + inotify to achieve real-time synchronization

1, install rsync

You can install rsync service via yum source
[Root @ dg test] # yum install rsync

You can also install the source package
 wget http://rsync.samba.org/ftp/rsync/src/rsync-3.0.9.tar.gz
[Root @ dg test] #tar zxvf rsync-3.0.9.tar.gz
[Root @ dg test] #cd rsync-3.0.9
[Root @ dg test] #. / Configure --prefix = / usr / local / rsync
[Root @ dg test] # make
[Root @ dg test] #make install

make -j 4 # make compile the source code is compiled into a binary executable file -j 4 compiled using four processes simultaneously, taking the number of cpu, do not exceed the number of cpu

For example: at the source has a directory under / tmp / test there next file syncs sink, but this method only manual synchronization, can not achieve real-time synchronization
[Root @ dg test] # rsync -azP --delete / tmp / test root@ / data

Note: rsync is based on the ssh protocol, we need to know the server root and password
-a, archive (Archive) archiving mode represents recursively transfer files, and to maintain stable properties, is equivalent to adding a parameter -riptgoD
-z --compress represents compression
-P Shows the transmission speed
--delete delete those target end position and have no original location of the file

Add ssh key service, the next you can not enter a password
[Root @ dg bin] # ssh-keygen
Generating public / private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa):
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
1e: 5f: 6e: fe: 15: a6: c1: 12: d7: 1d: 4c: 79: c5: 9f: a3: 9d root @ dg

A copy of the trust relationship to the target end

[Root @ dg .ssh] # ssh-copy-id root@


See key target segment has elapsed
[Root @ rac2 .ssh] # ls
authorized_keys known_hosts

Without entering a password, this way no password synchronization
[Root @ dg .ssh] # ssh root@
Last login: Wed Jan 20 10:42:22 2016 from
[Root @ rac2 ~] #

2 Installing inotify

[Root @ dg test] #tar zxvf inotify-tools-3.14.tar.gz
[Root @ dg test] # cd inotify-tools-3.14
[Root @ dg test] # ./configure --prefix = / usr / local / inotify
[Root @ dg test] # make
[Root @ dg test] # make install

inotifywait -mrq -e create, move, delete, modify / tmp / test
-e change attribute is used to specify which events you want to monitor these events include create, create, move move, delete delete, modify content attrib
-m indicates continuous monitoring
-r recursive monitoring indicates
-q represents a simplified output

Also open a window:
root @ dg test] # cp / etc / group / tmp / test
[Root @ dg ~] # inotifywait -mrq -e create, move, delete, modify / tmp / test
/ Tmp / test / CREATE group
/ Tmp / test / MODIFY group

From this it can be seen inotifywait can capture files created message

3 Create rsync replication script

This function is mainly to the server side of the / tmp directory in the content, if you modify (either to add, modify, delete files) can be monitored via inotify, and through rsync real-time synchronization to the client in the / tmp, the following is by shell script to achieve.

[Root @ dg test] # cat rsync.sh
#! / Bin / bash
host =
src = / data
des = / data2
user = root
/ Usr / local / inotify / bin / inotifywait -mrq --timefmt '% d /% m /% y% H:% M' --format '% T% w% f% e' -e modify, delete, create , attrib $ src | while read files
/ Usr / bin / rsync -vzrtopg --delete $ src $ user @ $ host: $ des
echo "$ {files} was rsynced" >> / rsync.log 2> & 1

Wherein the host is a client's ip, src is a server-side real-time monitoring to the directory, des is certified module name, needs to be consistent with the client, user is creating a password file authentication user.
This script named rsync.sh, put monitoring directory, for example, I would put / tmp below, and give 764 permissions, suggest that it rsync log into other directories (non-backup directory).
[Root @ dg test] # chmod 764 rsync.sh

Then run this script
[Root @ dg test] # sh /tmp/rsync.sh &

We can also put rsync.sh script to the boot entry in
echo "/tmp/rsync.sh" >> /etc/rc.local
- How to use the internal network IP forwarding to connect to the Internet on Linux (Linux)
- Use LVM partition on Ubuntu and easily adjust the snapshot (Linux)
- MySQL migration tool used in the production environment (Database)
- The development environment to build Nodejs under Ubuntu 14.04 (Linux)
- How to view the Linux QPS (Linux)
- MySQL master recovery from failure using binlog (Database)
- Wi-Fi hackers use to attack your seven methods (Linux)
- Android Send HTTP POST requests (Programming)
- E: Sub-process / usr / bin / dpkg returned an error code (1) error solution (Linux)
- Timeout control related to Python threads and a simple application (Programming)
- Installation Atom text editor on Mint Ubuntu / Linux (Linux)
- Android timer use (Programming)
- Shell scripts to copy all directories under the current directory of a certain type of file to the same directory (Linux)
- How to install Unbound and DNSCrypt in Archlinux (Server)
- Learning UNIX good habits (Linux)
- How to install Visual Studio Code on Ubuntu (Linux)
- The ActiveMQ JMS installation and application examples for Linux (Linux)
- Oracle 11g em start newspaper site's security certificate has a solution to the problem (Database)
- Linux common commands MEMO (Linux)
- Use Markdown editor for document work under Linux (Linux)
  CopyRight 2002-2020 newfreesoft.com, All Rights Reserved.