ホームページ > データベース > mysql チュートリアル > Mysql innodb は、カーネル バッファをバイパスし、Linux で直接 I/O を実現するように raw を設定します。

Mysql innodb は、カーネル バッファをバイパスし、Linux で直接 I/O を実現するように raw を設定します。

PHP中文网
リリース: 2017-07-04 19:31:17
オリジナル
1047 人が閲覧しました

(Linuxコミュニティから転載)

MySQL の InnoDB ストレージ エンジンは、インデックスをキャッシュするだけでなく、そのテーブルとインデックスが RAW デバイス (Raw Device) に保存されている場合、ファイル システムのキャッシュとバッファをバイパスしてディスクに直接アクセスすることもできます。 Linux ファイル システムへの負担が大幅に軽減され、システム パフォーマンスが大幅に向上します。

さらに、データベース アプリケーションにおけるベア デバイスの最適化原則から、データベースを最適化する基本的な方向性は、デバイス固有の I/O 集中型アクセスによって引き起こされるファイル システムへの大きな負荷を軽減する方法であることもわかります。データベース。したがって、既存のファイル システム ベースのデータベース ストレージ エンジンでも、特別なファイル システム マウント方法を検討できます。
たとえば、データベース ファイルを保存するパーティションのマウント パラメーターとして noatime を使用すると、アクセス時間が記録されなくなるため、システムのパフォーマンスがある程度向上します。

─────────────────── ────────────
このノートで設定されている最新のシステム環境:
──────── ─────────────────── ──────────
OS: CentOS6
HDD: /dev/sdc /dev/sdd
RAW: /dev/raw/raw1 /dev/raw/raw2
MySQL: 5.1.61
USER: mysql:mysql

公式ウェブサイトの設定ガイドを参照してください:

─────────────────── ───────────────────
(1) rawデバイスを準備します
─────── ───────────────────── ──────────
raw デバイスを使用する前に、まずディスク デバイスを raw デバイスにバインドする必要があります。

# /bin/raw /dev/raw/raw1 /dev/sdc;
-------------------------------- --------------------------------------
/ dev/raw/raw1: バインドされていますメジャー8、マイナー32
------------------------------------------ ---- ------------------------------------------------

別の raw デバイスをバインドし、MySQL データベースの実行ユーザーに raw デバイスの読み取りと書き込みの権限を与えます。

# /bin/raw /dev/raw/raw2 /dev/sdd;

# chown root:mysql /dev/raw/raw1 /dev/raw/raw2;
# chmod 0660 /dev/raw/raw1 /dev/raw /raw2;

# /bin/raw -qa;
# /bin/raw -q /dev/raw/raw1;
# /bin/ls -l /dev/raw/raw1;
# blockdev --report /dev/raw /raw1;
# blockdev --report /dev/sdc;

vi /etc/udev/rules.d/60-raw.rules;
---------------------------- -------------------------------------------------- --
ACTION=="add"、KERNEL=="sdc"、GROUP=="mysql"、MODE=="0660"、RUN+="/bin/raw /dev/raw/raw1 %N"
ACTION= ="追加 "、KERNEL=="sdd"、GROUP=="mysql"、MODE=="0660"、RUN+="/bin/raw /dev/raw/raw2 %N"
------ --- --------------------------------------------------- --- --------------------
注: これにより、サーバーの再起動時にデバイス /dev/sdc と /dev/sdd が​​自動的にバインドされるようになります。

# vi /etc/udev/rules.d/41-local-permissions-rules;

─────────────────── ──────────

(2) 必要に応じて、最初に古い InnoDB データ テーブルをバックアップします
──── ──── ───────────────── ─----------------------------
データベースがすでに実行中で、既存のデータが古い InnoDB エンジンに保存されている場合、移行する必要がある場合は、
mysqldump コマンドを使用してエクスポートしてください。データベースを閉じる前にデータを保存し、新しいエンジンが構成された後にインポートします。

次の SQL コマンドを参照して、InnoDB データ テーブルを表示およびエクスポートできます:

mysql> SELECT テーブル スキーマ, テーブル名, エンジン FROM INFORMATION_SCHEMA.TABLES;

mysql> SELECT テーブル スキーマ, テーブル名 FROM INFORMATION_SCHEMA.TABLES WHERE エンジン='InnoDB';

必要に応じて、mysqldump を使用してデータをエクスポートできます。次の形式を参照してください (対応するデータベース名とテーブル名を使用してください)。

mysqldump -u root -p -h localhost [データベース].[テーブル] >

注: 古いデータはテーブルごとにエクスポートする必要があります。

─────────────────── ────────────
(3) 初期化フェーズ中の MySQL 設定
──────── ───────────────── ──────────
新しいデータ ファイルを作成するときは、innodb_data_file_path:
のデータ ファイル サイズの直後にキーワード newraw

を入力します。

# vi /etc/my.cnf;
-------------------------------------- ------ -------------------------------------------- ----
[mysqld]
innodb_buffer_pool_size=128M
innodb_data_home_dir=
innodb_data_file_path=/dev/raw/raw1:64Mnewraw;/dev/raw/raw2:64Mnewraw
-------------- ------------------------ -------------------------------------------- ------------- ---

追記:

mysql は別の実装方法も提供しており、my.ini で innodb_flush_method を設定します

innodb_flush_method = O_DIRECT

これにより、直接 I/O も実現できます

以上がMysql innodb は、カーネル バッファをバイパスし、Linux で直接 I/O を実現するように raw を設定します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート