Linuxサーバー間のリアルタイムファイル同期の実現

Linuxサーバー間のリアルタイムファイル同期の実現

使用シナリオ

既存のサーバー A と B の場合、サーバー A の指定されたディレクトリ (たとえば、 /home/paul/rsync/ ) の内容が変更されると (追加、削除、変更、属性の変更)、これらの変更はサーバー B のターゲット ディレクトリ (たとえば、 /home/paul/rsync/ ) にリアルタイムで同期されます。

データミラーリングバックアップツール Rsync

Rsync は非常に高速かつ柔軟なファイルコピー ツールです。ローカル マシンとリモート サーバー間のファイルのコピーをサポートします。 Rsync はデルタ転送アルゴリズムを使用します。このアルゴリズムでは、ソース ファイルとターゲット ファイル間の差分のみを転送する必要があるため、ネットワーク帯域幅の消費とコピーにかかる時間が大幅に削減されます。 Rsync は主にデータのバックアップとミラーリングに使用されます。

Rsync は、ファイル サイズまたは最終変更時刻の変更を比較して、ファイルを同期する必要があるかどうかを判断する高速チェック アルゴリズムを使用します。

Rsync を使用してリモート ホストに接続するには、ssh を使用する方法と rsync デーモンを使用する方法の 2 つがあります。ここでは、リモート ファイルのバックアップを実装するために Rsync が使用されます。

Rsyncのインストールと操作

Rsyncをインストールする

サーバー A とサーバー B のターミナルでそれぞれ実行します。

sudo yum rsyncをインストールします

インストールが完了すると、rsync 構成ファイルが etc/rsyncd.conf にあることがわかります。このファイルは、デーモンを同期に使用する場合に必要ですが、ここでは紹介されていません。

サーバーAとB間のパスワードなしのログインを構成する

サーバーAは次を実行します:

sshキー生成
ssh-copy-id サーバーBのIPアドレス

ソースディレクトリとターゲットディレクトリを作成する

サーバーAの場合:

mkdir /home/paul/rsync

サーバーBの場合:

mkdir /home/paul/rsync

サーバーAにテストファイルを作成する

echo "サーバー A からこんにちは" >> /home/paul/rsync/demo.txt

ファイル転送コマンドを実行する

サーバー A で以下を実行します。

#(1)
rsync -avPz --progress /home/paul/rsync 192.168.100.130:/home.paul/rsync
#(2)
rsync -avPz --delete --progress /home/paul/rsync 192.168.100.130:/home.paul/rsync

サーバー B の /home/paul/rsync ディレクトリにも demo.txt が表示されます。

コマンド分析:

(1)サーバーAの/home/paul/rsyncディレクトリにあるファイルをサーバーB(192.168.100.130)の/home.paul/rsyncにコピーします。

(2)ターゲット側のファイルとソース側のファイルを比較します。ターゲット側のファイルがソース側に存在しない場合は、ターゲット側のファイルを削除します。

Rsync の問題

Rsync は単なるファイル コピー ツールであり、ソース ファイルの追加、削除、変更操作を監視することはできません。ソース側で変更を行った後、rsync コマンドを実行して変更をターゲット側に同期する必要があります。

Rsync は、各同期の前にディレクトリ全体をスキャンする必要があります。ソースディレクトリに多数のファイルがある場合、スキャンに時間がかかることがあります。
リアルタイム監視の要件を満たすには、inotify という別のツールを導入する必要があります。

ファイルシステムイベント監視ツール inotify

inotify-tools は、inotify へのシンプルなインターフェースを提供します。これは C 言語で書かれたライブラリであり、コマンドライン ツールも含まれています。

inotify-tools の詳細な紹介については、こちらをクリックしてください: https://github.com/rvoicilas/inotify-tools/wiki

inotify-toolsのインストール

Centos7 システムの場合は、次の順番で実行します。

yum インストール -y epel-release
yum --enablerepo=epel で inotify-tools をインストールします

inotifywaitコマンドを使用してイベントを監視する

監視スクリプトは次のとおりです (inotifywait-rsync.sh)。

inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' -e 変更、削除、作成、属性 /home/paul/rsync/ | ファイルの読み取り中
する
rsync -avPz --progress /home/paul/rsync/ 192.168.100.130:/home/paul/rsync/
rsync -avPz --delete /home/paul/rsync/ 192.168.100.130:/home/paul/rsync/
echo "${file} が同期されました"
終わり

パラメータ解析

  • -m は監視を続けます。このパラメータが設定されていない場合、inotifywait は 1 つのイベントを監視した後に終了します。
  • -r ディレクトリを再帰的に監視します。
  • -q 静音モード、出力を少なくします。
  • --timefmt は時間の出力形式を指定します。
  • --format イベント出力の形式を指定します。
  • -e 監視するイベント タイプを設定します。ここでは、追加、削除、変更、メタデータの変更を監視します。

トリガーされたリスニング時間ごとに、inotifywait は do と done の間のコードを実行します。ここでは、前述の rsync コマンドを呼び出してファイルを同期します。

監視スクリプトをcrontabに追加する

crontab -e
* * * * * sh /home/paul/inotifywait-rsync.sh

参考文献
https://rsync.samba.org
https://github.com/rvoicilas/inotify-tools/wiki

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • Linuxはscpコマンドを使用してファイルをローカルコンピュータにコピーし、ローカルファイルをリモートサーバーにコピーします。
  • Linux サーバーでフォルダー、ファイル、解凍コマンドを削除する方法
  • Samba を使用して Linux サーバー上で共有ファイル サービスを構築する方法
  • Linux サーバーと Windows システム間でファイルをアップロードおよびダウンロードする方法
  • PythonはLinuxサーバー上のファイルを読み取る
  • SSH経由でLinuxサーバーにファイルやフォルダをアップロードする方法
  • Linux ローカルとサーバー間でファイルを転送し、Linux サーバー上でファイルをアップロードおよびダウンロードするためのコマンドを記述する方法
  • 2 つの Linux サーバー間の自動ファイル同期

<<:  jQueryはシンプルなコメントエリアを実装します

>>:  MySQLは1つのテーブルからデータをクエリし、それを別のテーブルに挿入する実装方法

推薦する

Javascript 仮想 DOM の詳細な説明

目次仮想DOMとは何ですか?なぜ仮想DOMが必要なのでしょうか?仮想 DOM はどのようにして実際の...

React Native スキャフォールディングの基本的な使い方の詳細な説明

プロジェクトを構築する対応するパスでコマンドラインを実行します: react-native init...

Linux でのソース パッケージ インストールのサービス管理

目次1. ソースパッケージサービスの起動管理2. ソースパッケージサービスのセルフスタート管理3. ...

Angular構造ディレクティブモジュールとスタイルの詳細な説明

目次1. 構造指示モジュールforRoot()を書く3. スタイルの定義ドラッグ時の順序を調整するに...

スタイルを書く際の背景色宣言の重要性

タイトルの通り、ページを修正すると以下のような状況が発生する可能性があります。現在、古いページを改修...

Linux カーネル デバイス ドライバー カーネル時間管理に関する注意事項

/****************** * Linux カーネルの時間管理 ***********...

html.cssオーバーフローの包括的な理解

html.cssオーバーフローの包括的な理解XML/HTML コードコンテンツをクリップボードにコピ...

MySQL GTID マスターとスレーブの不一致を修復するソリューション

目次解決策1: レプリカを再構築する前提条件アドバンテージ欠点手順マスター奴隷解決策2: データ修復...

HTML チュートリアル: HTML 水平線分

<br />このタグを使用すると、画面上に水平線を表示して、ページのさまざまな部分を区切...

Nginx に lua-nginx-module モジュールをインストールする方法

ngx_lua_module は、lua パーサーを nginx に埋め込み、lua 言語で記述され...

LinuxにComposerをインストールする方法

1. インストールスクリプト(composer-setup.php)を現在のディレクトリにダウンロー...

CSS3で実装された6つの境界遷移効果

6つの効果実装コードhtml <h1>CSS 境界遷移</h1> <セ...

VMware仮想マシンにLinux(CentOS)をインストールするための詳細な構成手順

CentOS7をダウンロード私がダウンロードしたイメージはCentOS-7-x86_64-DVD-1...

MySQL メタデータで Hive テーブル作成ステートメントのコメント スクリプトを生成する方法

序文この記事は主にMySQLメタデータ生成Hiveテーブル作成ステートメントコメントスクリプトに関す...

webpackのモバイル適応ソリューションの概要

目次レムフォルクスワーゲンサードパーティのUIフレームワークに適応する結論モバイル開発における最も一...