


How to implement real-time file synchronization between two servers under Linux
Assume the following requirements:
Assume two servers:
192.168.0.1 The source server has the directory /opt/test/
192.168.0.2 The target server has the directory /opt/bak/test/
The purpose of implementation is to maintain real-time synchronization of a file directory on the two servers
Implementation method: through rsync+inotify -Tools combination to achieve
Preparation work:
First, add a trust relationship to the two machines. The specific method has been introduced in the previous article
View details: linuxAdd trust relationship and log in without password
RequiresInstallationsoftware:
1. rsync synchronization software
Need to be installed on both the source server and the target server
Source server: It is an rsync client, no configuration is required
Target server: It is an rsync server, it needs to be configured in /etc/rsyncd.conf Content
2. inotify-tools tool
This tool is a real-time file monitoring tool that requires Linux operating system kernel support. Kernel support requires at least version 2.6.13
Check whether the operating system supports it. Execute as follows:
uname -r View version
Return:
2.6.32-358.6.1.el6.x86_64
If version 2.6.32 is greater than 2.6.13, it is supported.
Execution:
ll /proc/sys/fs/inotify total 0 -rw-r--r-- 1 root root 0 Oct 18 12:18 max_queued_events -rw-r--r-- 1 root root 0 Oct 18 12:18 max_user_instances -rw-r--r-- 1 root root 0 Oct 18 12:18 max_user_watches
If there are three outputs, it means that inotify is supported by default and you can install the inotify-tools tool.
If it is not supported, you need to use a new version of the linux operating system
If the version meets the requirements, it can be installed.
After installing inotify-tools, the following two files will be generated in the relevant installation directory:
ll /usr/local/bin/ total 88 -rwxr-xr-x 1 root root 44327 Oct 10 15:32 inotifywait -rwxr-xr-x 1 root root 41417 Oct 10 15:32 inotifywatch
It means the installation is successful.
Note: It needs to be installed on the source server, and inotify does not need to be installed on the target server.
3. Related scripts:
Create a new script on the source server:
inotify_bak.sh
#!/bin/bash src=/opt/test/ /usr/local/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f%e' -e close_write,delete,create,attrib $src | while read file do /usr/bin/rsync -arzuq $src 192.168.0.1::www/ echo " ${file} was rsynced" >>/opt/soft/log/rsync.log 2>&1 done
Grant execution permissions: chmod +x inotify_bak.sh
Then execute: nohup inotify_bak.sh & Put it in the background for execution
4. About starting
Target server: first Start the rsync background service: /usr/bin/rsync --daemon
Source server: Execute inotify_bak.sh &
5. Test:
Create a new file in the source server directory Directories and files, the inotify_bak.sh script will detect them and then synchronize them to the relevant directories of the target server
You can view the log file: /opt/soft/log/rsync.log The command is as follows: observe the real-time synchronization situation .
tail -f /opt/soft/log/rsync.log
Error resolution:
/usr/local/bin/inotifywait: error while loading shared libraries: libinotifytools.so.0: cannot open shared object file: No such file or directory
This is because the library file cannot be found, just make a soft connection
ln -s /usr/local/lib/libinotifytools.so.0 /usr/lib64/libinotifytools.so.0
The above is the detailed content of How to implement real-time file synchronization between two servers under Linux. For more information, please follow other related articles on the PHP Chinese website!

In Linux, file and directory management uses ls, cd, mkdir, rm, cp, mv commands, and permission management uses chmod, chown, and chgrp commands. 1. File and directory management commands such as ls-l list detailed information, mkdir-p recursively create directories. 2. Permission management commands such as chmod755file set file permissions, chownuserfile changes file owner, and chgrpgroupfile changes file group. These commands are based on file system structure and user and group systems, and operate and control through system calls and metadata.

MaintenanceModeinLinuxisaspecialbootenvironmentforcriticalsystemmaintenancetasks.Itallowsadministratorstoperformtaskslikeresettingpasswords,repairingfilesystems,andrecoveringfrombootfailuresinaminimalenvironment.ToenterMaintenanceMode,interrupttheboo

The core components of Linux include kernel, file system, shell, user and kernel space, device drivers, and performance optimization and best practices. 1) The kernel is the core of the system, managing hardware, memory and processes. 2) The file system organizes data and supports multiple types such as ext4, Btrfs and XFS. 3) Shell is the command center for users to interact with the system and supports scripting. 4) Separate user space from kernel space to ensure system stability. 5) The device driver connects the hardware to the operating system. 6) Performance optimization includes tuning system configuration and following best practices.

The five basic components of the Linux system are: 1. Kernel, 2. System library, 3. System utilities, 4. Graphical user interface, 5. Applications. The kernel manages hardware resources, the system library provides precompiled functions, system utilities are used for system management, the GUI provides visual interaction, and applications use these components to implement functions.

Linux maintenance mode can be entered through the GRUB menu. The specific steps are: 1) Select the kernel in the GRUB menu and press 'e' to edit, 2) Add 'single' or '1' at the end of the 'linux' line, 3) Press Ctrl X to start. Maintenance mode provides a secure environment for tasks such as system repair, password reset and system upgrade.

The steps to enter Linux recovery mode are: 1. Restart the system and press the specific key to enter the GRUB menu; 2. Select the option with (recoverymode); 3. Select the operation in the recovery mode menu, such as fsck or root. Recovery mode allows you to start the system in single-user mode, perform file system checks and repairs, edit configuration files, and other operations to help solve system problems.

The core components of Linux include the kernel, file system, shell and common tools. 1. The kernel manages hardware resources and provides basic services. 2. The file system organizes and stores data. 3. Shell is the interface for users to interact with the system. 4. Common tools help complete daily tasks.

The basic structure of Linux includes the kernel, file system, and shell. 1) Kernel management hardware resources and use uname-r to view the version. 2) The EXT4 file system supports large files and logs and is created using mkfs.ext4. 3) Shell provides command line interaction such as Bash, and lists files using ls-l.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Atom editor mac version download
The most popular open source editor

Dreamweaver Mac version
Visual web development tools

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function