Home PC Games Linux Windows Database Network Programming Server Mobile  
           
  Home \ Server \ rsync + inotify to achieve real-time synchronization     - Android development environment to build under Fedora 13 (Linux)

- Analysis examples: Intrusion Response Linux platform Case (Linux)

- Linux, modify the hostname (Linux)

- C ++: Postmodern systems programming language (Programming)

- Analytical Ceph: handle network layer (Server)

- Android memory optimization of the memory cache (Linux)

- How to understand Python yield keyword (Programming)

- Shell Common Command Summary (Programming)

- Du and df show disk space usage inconsistent Causes and Treatment (Linux)

- GNU / Linux system, how to clean up memory space (Linux)

- Java Concurrency -volatile keywords (Programming)

- C ++ class implementation date operator overloading (Programming)

- Installation Eduspec university management systems 17 Linux Mint (Server)

- View processes and threads under Linux (Linux)

- Help you to see Linux system architecture type 5 Common Commands (Linux)

- Xtrabackup creates a slave node without downtime (Database)

- Django1.8 return json json string and the string contents of the received post (Programming)

- Linux under HAProxy + Keepalived dual-availability program (Server)

- Based Corosync + Pacemaker + DRBD + LNMP Web server to achieve high availability cluster (Server)

- Memcached source installation and configuration under CentOS 6.6 (Server)

 
         
  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 10.10.6.82:/data, but this method only manual synchronization, can not achieve real-time synchronization
[Root @ dg test] # rsync -azP --delete / tmp / test root@10.10.6.82: / 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@10.10.6.82

 


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

Without entering a password 10.10.6.82, this way no password synchronization
[Root @ dg .ssh] # ssh root@10.10.6.82
Last login: Wed Jan 20 10:42:22 2016 from 10.10.8.54
[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 = 10.10.6.82
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
do
/ Usr / bin / rsync -vzrtopg --delete $ src $ user @ $ host: $ des
echo "$ {files} was rsynced" >> / rsync.log 2> & 1
done

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
     
         
         
         
  More:      
 
- How to use the process on the desktop xkill end Linux (Linux)
- Linux monitoring tools introduced series --smem (Server)
- Apache Mina framework Practice (Programming)
- SELinux multi-level security (Linux)
- Linux using DenyHosts prevents ssh cracks (Linux)
- Mongo-connector integrated MongoD to achieve incremental Solr index (Server)
- CentOS7 virtual machine settings, and bridging problems (Linux)
- Linux can modify the maximum number of open files (Linux)
- Oracle 11.2.0.3 and MySQL5.6 DDL comparison (Database)
- ThinkPad X201i installation notes Debian 7.5 (Linux)
- GDB remote connections RX Probe online debug program (Programming)
- DRBD installation configuration, working principle and Recovery (Server)
- shell script: MySQL startup script simple (Database)
- React Native (Programming)
- A detailed introduction to the Hadoop ecosystem (Server)
- Why HBase need to build SQL engine layer (Database)
- Python uses multi-process pool (Programming)
- Linux daemon (Linux)
- Access.log Apache access log analysis and how to import it into MySQL (Server)
- RT-11SJ run at ambient PDP-11 MACRO-11 assembly (Programming)
     
           
     
  CopyRight 2002-2022 newfreesoft.com, All Rights Reserved.