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つのテーブルからデータをクエリし、それを別のテーブルに挿入する実装方法

推薦する

MySQL の悲観的ロックと楽観的ロックの理解と応用分析

この記事では、例を使用して MySQL の悲観的ロックと楽観的ロックについて説明します。ご参考までに...

MySQLでグローバル変数とセッション変数を設定する2つの方法の詳細な説明

1. MySQL でグローバル変数を変更するには 2 つの方法があります。方法 1: my.ini ...

この記事ではMySQLのNULLについて説明します。

目次序文MySQL の NULL 2 NULL占有長3 NULL値の比較4SQLはNULL値を処理す...

HTMLとは何ですか?

HTML 開発の歴史: HTML は英語で Hypertext Marked Language の...

Dockerコンテナでルート権限を取得する方法

まず、コンテナが稼働している必要がありますコンテナのCONTAINER IDは、sudo docke...

ボタンのタイプが送信として指定されていません。ボタンをクリックしても、指定された URL にジャンプしません。

現在、プロジェクトの要件により、フォームの送信を制御し、送信前にデータを検証および処理するために j...

CSS3を使用してテキストの垂直配置を実現する方法

最近のプロジェクトでは、テキストを垂直に揃えたいと考え、CSS の writing-mode プロパ...

Windows 上の MySQL バージョン 5.7 でエンコードを UTF-8 に変更する方法

序文MySQLの勉強を始めたばかりで、公式サイトから最新バージョン5.7.14をダウンロードしました...

MySQLストアドプロシージャの原理と使用法の詳細な説明

この記事では、例を使用して、MySQL ストアド プロシージャの原理と使用方法を説明します。ご参考ま...

CSSレイアウトで中央揃えレイアウトを実現する方法

1. 親コンテナーをテーブルに設定し、子をインライン要素に設定します。テキストを表示するサブコンテン...

JavaScriptの擬似配列と配列の使い方と違い

擬似配列と配列JavaScript では、5 つのプリミティブ データ型を除き、関数を含め、その他す...

JavaScript における BOM と DOM の詳細な説明

目次BOM (ブラウザ オブジェクト モデル) 1. ウィンドウブラウザのウィンドウサイズを取得する...

Webデザインチュートリアル(2):模倣と盗作について

<br />前回の記事では、Webデザインの手順と方法を紹介しました。詳細については、前...