Linux inotifyリアルタイムバックアップの実装方法の詳細説明

Linux inotifyリアルタイムバックアップの実装方法の詳細説明

リアルタイム レプリケーションは、企業データをバックアップする最も重要な方法です。主に、ユーザーが送信したデータのバックアップに使用されます。ユーザーがサーバーに送信する通常のファイル (画像、圧縮パッケージ、ビデオ、ドキュメントなど) の場合、inotify/sersync+rsync リアルタイム バックアップ メソッドを使用できます。データ ファイルの場合、FastDFS、GlusterFS など、同時に複数のコピーにデータをバックアップできるより複雑な分散ストレージ ツールがあります。データベースに送信されたデータの場合、データベースのマスター スレーブ レプリケーション (MySQL、Oracle など) を使用してバックアップできます。これは、ソフトウェアに付属するリアルタイム レプリケーション バックアップ メソッドです。一部の企業では、データが同時に複数のコピーに変換されることを実現するために、さらに多くのアイデアを採用しています。たとえば、データを送信するときに、プログラムのビジネス ロジックが 2 つのサーバーに同時に送信されます。

リアルタイムのレプリケーション展開準備をシミュレートする

リアルタイムレプリケーションソフトウェアの紹介

よく使用されるソフトウェア: inotify-tools、sersync (推奨)

リアルタイムレプリケーションinotifyメカニズムの紹介

Linux カーネルは 2.6.13 以降、Inotify サポートを追加しました。これは非同期のシステム イベント監視メカニズムです。inotify を通じて、ファイル システムでの追加、削除、変更、移動などのさまざまなイベントを監視できます。このカーネル インターフェイスを使用すると、サードパーティ ソフトウェア (inotify-tools、sersync など) はファイル システム内のさまざまなファイルの変更を監視し、リアルタイムで応答できます。

注: sersync ソフトウェアは inotify に基づいて開発されており、より強力な機能を備えています。構成ファイル、スケジュールされた再試行レプリケーション、フィルタリング メカニズムをサポートし、CDN データ更新用のインターフェイスを提供し、マルチスレッド操作をサポートします。

長所と短所

inotify の利点: ファイル システム イベントの変更を監視し、レプリケーション ツールを通じてリアルタイムのデータ レプリケーションを実現します。マルチスレッドのリアルタイムレプリケーションをサポートします。

inotify の欠点: 同時コピーの数が 200 ファイル (10 ~ 100k) を超えると、コピーに遅延が発生します。

解決策: フロントデスクで時間を稼ぎます。たとえば、アカウントを登録したり、データをアップロードして [送信] をクリックすると、ページが数秒間表示され、その後元のページに戻ります。

inotify+rsync プロジェクトの実践

1. rsync サービスが利用可能であり、nfs01 サーバーからバックアップ サーバーにデータをプッシュおよびプルできることを確認します。

2. システムサポートを確認する

①カーネルバージョンが2.6.13以上であること ②以下の3つのファイルが存在している必要がある

3. inotify-toolsソフトウェアをテストする

[root@nfs01 ~]# yum install inotify-tools -y

テストするには 2 つのウィンドウを開きます。

スクリプトの作成:

注: 別の nfs01 ウィンドウを開いてファイルを作成、変更、削除し、バックアップ サーバー上でファイルがリアルタイムで同期されているかどうかを確認します。

4. sersyncソフトウェアをテストする

パッケージをアップロード

解凍

tar -xf sersync2.5.4_64bit_binary_stable_final.tar.gz -C /application/sersync/

sersync の設定ファイルは XML ファイルです。まずはバックアップしてください。cp confxml.xml{,.ori}

設定ファイルを変更します (行番号を表示するには :set nu と入力します)。

埋め込む

sersyncはyumによってインストールされないため、systemctlコマンドを使用して起動、停止、再起動することはできません。

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

以下もご興味があるかもしれません:
  • LinuxはRsync+Inotifyを使用してローカルとリモートのデータのリアルタイム同期を実現します。
  • Linux の Pyinotify モジュールを使用してファイルシステムの変更をリアルタイムで監視する
  • Linux inotify を使用してファイルの状態を監視する方法
  • Linux システムで rsync+inotify を使用してサーバー間のファイルのリアルタイム同期を実現する
  • rsync+inotify を介して Linux システム内の Web ページを自動的に同期する
  • Linux 上で rsync+inotify によるリアルタイム データ バックアップを実現 (リモート災害復旧バックアップ システム)

<<:  MySqlデータベースの基礎知識のまとめ

>>:  ウェブページの画像の回転を実現するjs

ブログ    

推薦する

ウェブデザインと制作におけるハイパーリンクの効果の向上

ハイパーリンクを使用すると、ページからページへ、またはサイトからサイトへ瞬時に移動できます。このよう...

純粋なCSSを使用してスイッチ効果を実現する

まずアイデアはこの効果を実現するには、 <input type="checkbox&...

MySQLトリガーの使用例の詳細

MySQL トリガー構文の詳細: トリガーは、特定のテーブル内のデータが挿入、削除、または更新される...

フォーム入力ボックスに関するWebデザインのヒント

この記事では、Web デザインにおけるフォーム入力ボックスに関するヒントとコードをいくつか紹介します...

CSS3 を使用して色付きのプログレスバーアニメーションを実装する例

簡単なチュートリアルこれは CSS3 カラー プログレス バー アニメーション効果です。 CSS3 ...

Docker 上で Redis クラスターを構築する

目次1. イメージをプルする2. Redisコンテナを作成する3. コンテナを起動するためにクラスタ...

Vue で $attrs と $listeners を使用するチュートリアル

目次導入例要約する導入$属性すべての親コンポーネントのプロパティを継承します (props を通じて...

Webpackプラグインを書いてnpmに公開するための80行のコード

1. はじめに最近、 Webpackの原理を勉強しています。これまでは Webpack の設定方法し...

MySQLステートメントの記述と実行順序を理解するだけです

MySQL ステートメントの書き込み順序と実行順序には大きな違いがあります。書き順、mysql の一...

ブラウザタブの左端に表示されるウェブサイトのアイコンを設定します

この文の目的は何ですか?コードをコピーコードは次のとおりです。 <link rel="...

MySQL エンコーディング utf8 および utf8mb4 utf8mb4_unicode_ci および utf8mb4_general_ci

参考: MySQL 文字セットの概要utf8mb4 は MySQL 8.0 のデフォルトの文字セット...

MySQL全文検索の使用例

目次1. 環境整備2. データの準備3. ショーを始める4. 単語分割エンジン要約する参考文献1. ...

バントリストコンポーネントをスクロールしても、スクロールバーの位置は保持されます。

バントリストコンポーネントをスクロールするときに、スクロールバーの位置が保持されます。これは、kee...

MySQL 5.7 のインストールと設定方法のグラフィックチュートリアル

このチュートリアルでは、MySQL 5.7のインストールと設定方法を参考までに紹介します。具体的な内...

MySQL の InnoDB ストレージ ファイルの詳細な説明

物理的に言えば、InnoDB テーブルは、共有テーブルスペース ファイル (ibdata1)、排他テ...