ホームページ >データベース >mysql チュートリアル >ビッグデータ学習パート 2 MYSQL 上級
#記事ディレクトリ
次に、より一般的に使用されるストレージをいくつか選択します エンジンの簡単な説明 ストレージ エンジンmysql で使用されるデータはデータベースのパフォーマンスに直接影響しますので、ストレージ エンジンを使用する前にストレージ エンジンの特性をよく理解していただければ幸いです。
5.1 MyISAM
MyISAM は、MySQL5.5 より前のデフォルトのストレージ エンジンでした。このため、MyISAM ストレージ エンジンを使用するサーバーは依然として多数存在します。同時に、MyISAM は現在、多くのシステム テーブルと一時テーブルで使用されるストレージ エンジンです。ここで言及されている一時テーブルは、
を通じて作成されるテーブルではなく、作成中に使用されるデータの量を指します。ソートやグループ化などの操作一定のサイズを超えると、クエリ オプティマイザーによって一時テーブルが作成されます。 MyISAM ストレージ エンジンは、MYD と MYI で構成されます。MYD はデータ ファイルの拡張子で、MYI はインデックス ファイルの拡張子です。このストレージ エンジンは、これら 2 つの拡張子を持つデータ ファイルとインデックス ファイルにテーブルを格納します。
機能:同時実行性とロック レベル
MyISAM は、行レベルのロックではなくテーブル レベルのロックを使用します。つまり、テーブル内のデータは変更時に、テーブル全体をロックする必要があり、テーブルを読み取るときに共有ロックもすべてのテーブルに追加されます。ここから、MyISAM をエンジンとして使用するテーブルの読み取りおよび書き込み操作が相互に排他的であることがわかります。 MyISAM は同時読み取りおよび書き込み操作があまり得意ではないことがわかります。読み取り専用操作のみの場合、共有ロックは共有ロックをブロックしないため、同時実行性の点ではパフォーマンスは悪くありません。
テーブル損傷の修復
MyISAM は、予期せぬシャットダウンによって破損した MyISAM テーブルのチェックと修復をサポートしていますが、ここで説明する修復はデータの回復ではありません。MyISAM はトランザクション ストレージ エンジンではないため、実行できません。トランザクションの回復には関連ログが必要となるため、MyISAM テーブルの回復によりデータ損失が発生する可能性があることに注意してください。 MyISAM はフルテキスト インデックス作成をサポートしており、mysql5.7 より前にフルテキスト インデックス作成をネイティブにサポートする唯一の公式ストレージ エンジンでした。
MyISAM テーブルはデータ圧縮をサポートしています
MyISAM が大きな読み取り専用テーブルを表す場合、つまり、テーブルが作成されてデータがインポートされた後、テーブルに変更が加えられない場合、テーブルを圧縮してディスク I/O を削減できます。
バージョン 空間アプリケーション
Innodb は、MySQL 5.5 以降のバージョンのデフォルトのストレージ エンジンです。Innodb は、トランザクション ストレージ用のストレージ エンジンであり、トランザクション処理をサポートします。
Innodb には独自のテーブル スペースの概念があり、データは innodb_file_per_table
パラメータによって決定されるテーブル スペースに保存されます。このパラメータが ON
の場合、システム拡張子 ibd
を持つファイルが Innodb テーブルごとに作成されます。このパラメータが OFF
の場合、データはシステムの共有テーブル スペース (つまり ibdataX#) に保存されます。 ##、#XX
は数値を表し、デフォルトでは 1 から始まります。 このパラメータを表示するコマンドは次のとおりです:
show variables like 'innodb_file_per_table'; このパラメータを変更するコマンドは次のとおりです:
set global innodb_file_per_table=off;
##比較:
optimize table | システム ファイルを圧縮するコマンド
| を渡すと IO ボトルネックが発生します
Innodb に独立したテーブル スペースを使用する
mysqldump を使用してすべてのデータベース テーブル データをエクスポートします
# #Innodb はトランザクション ストレージ エンジンです トランザクションの ACID 特性 (前に紹介したアトミック性、一貫性など) を完全にサポートします
show Engine innodb status
5.2.4 該当するシナリオ
5.2.4 (拡張) ロックとは何ですか
5.2.3.1 ロックとは何ですか?
#ロックの主な機能は、共有リソースへの同時アクセスを管理することです#ロックはトランザクションの分離を実現するために使用されます
##5.2 .3.2 ロックの種類:5.2.3.3 書き込みロックと読み取りロックの互換関係(1行の互換性)
書き込みロック
書き込みロック | 非互換 | |
---|---|---|
読み取りロック | 非互換 | 互換性のある |
実際の状況では、結果は上の表の結果と異なる場合があります。主な理由は、Innodb のロック メカニズムが非常に複雑なものであり、最終結果に影響を与えるロックが多数あるためです。 5.2.3.4 ロックの粒度:
5.2.3.5 ブロッキングとデッドロック ブロッキング: ブロッキングは、異なるロック間の互換性関係が原因で発生します。ある時点で、あるトランザクションのロックは、別のトランザクションのロックが完了するまで待機する必要があります。占有しているリソースが障害を形成します。 5.3 CSV ストレージ エンジン CSV ストレージ エンジンは、csv ファイルを mysql テーブル ファイルとして処理できます。このストレージ エンジンのストレージ形式は通常の csv ファイルです。 CSV ストレージ エンジンの保存方法は非常に独特です。テーブルを MyISAM または Innodb に保存すると、これら 2 つのファイルはバイナリ形式で保存されるため、データ ファイルを直接参照できません。CSV ストレージ エンジンは異なります。CSV データは次の形式で保存されます。テキスト形式のファイル。つまり、more などのファイルを表示するコマンドを使用して表示することも、vi コマンドを使用して CSV ストレージ エンジン内のテーブルを表示および編集することもできます。形式と要件が満たされている限り、 CSV ファイルの要件を満たしている場合、データが破損することを心配する必要はありません。 5.3.1 CSV ストレージ エンジンの特徴
5.3.2 CSV ストレージ エンジンの適用可能なシナリオ CSV ストレージ エンジンはデータ交換に適しています中間テーブル 5.4.1 ファイル システム ストレージの特性 アーカイブストレージ エンジンはすべての書き込みをキャッシュし、zlib を使用して挿入された行を圧縮します。そのため、アーカイブ ストレージ エンジンは、MyISAM ストレージ エンジンのテーブルと比較してディスク I/O を節約します。同じ桁のデータの場合、アーカイブ ストレージ エンジンは、MyISAM と比較してストレージ スペースを節約します。そしてInnodb。アーカイブ ストレージ エンジンに保存される数テラバイトの Innodb テーブルには、数百メガバイトのストレージ スペースしか必要としない場合があります。 アーカイブ ストレージ エンジンのテーブル データは、ARZ というサフィックスを持つファイルですが、他のエンジンと同様に、テーブルの構造情報を格納するために使用される frm というサフィックスを持つシステム ファイルもあります。
シナリオ 1: ログおよびデータ収集クラス Data アーカイブは変更と削除をサポートしていないため、ORDB は間違いなくデータを変更しますが、一部のウェアハウス タイプのアプリケーションや、ログ テーブルやデータ収集テーブルなどの特殊なテーブルには依然として役立ちます。大量のデータを収集する必要があるため、アーカイブ ストレージ エンジンを使用します。アーカイブ ストレージ エンジンのストレージ容量はすべてのエンジンの中で最も小さいため、データ収集またはログ アプリケーションであっても、アーカイブ ストレージ エンジンはこれらのデータを更新できないことに注意してください。そのため、ログを記録するとき、またはデータ コレクション内のデータを変更する場合は、アプリケーションを使用すると、アーカイブ ストレージ エンジンを使用できない場合があります。
5.5.1 ファイル システム ストレージの特性 メモリ ストレージ エンジンは HEAP ストレージ エンジンとも呼ばれ、データはメモリに保存されます。これは、データ テーブルが使い捨てであることを意味します。MySQL サービスが再起動されると、すべてのメモリ ストレージ エンジンのデータが消去されます。ただし、テーブル構造はメモリ ストレージ エンジンの下でテーブルを作成すると、テーブル構造を保存するために使用される frm システム ファイルのみが生成されるため、このファイルは保持されます。これが、MySQL サーバーを再起動するとデータは失われますが、テーブル構造は失われない理由です。 5.5.2 メモリの機能特徴 機能特徴:
5.5.3 メモリの紛らわしい概念 メモリ ストレージ エンジン テーブル: 5.5.4 メモリ使用シナリオ
メモリ データは失われやすいため、データは再現可能である必要があります。 5.6 Federated Storage Engine 5.6.1 Federated の機能
5.6.2 Federated の使用方法 Federated Storage Engine はサーバーに接続する SQL Server の機能を実現しますが、独自のパフォーマンスにより、あまり良くありません。通常、レプリケーションなどを通じて同じ目的を達成できるため、現在の MySQL バージョンでは、フェデレーション ストレージ エンジンはデフォルトで無効になっています。 Federated Storage Engine を使用する必要がある場合は、 5.6.3 Federated に適用できるシナリオ
6 正しいストレージ エンジンの選択方法 参考条件:
|
以上がビッグデータ学習パート 2 MYSQL 上級の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。