MySQL アーキテクチャのナレッジポイントの概要

MySQL アーキテクチャのナレッジポイントの概要

1. データベースとデータベースインスタンス

MySQL の研究では、データベースとデータベース インスタンスという非常に混同しやすい 2 つの概念があります。 MySQL では、データベースとデータベース インスタンスは次のように定義されます。

データベース: 保存されたデータの集合。

データベース インスタンス: 運用データベースのコレクション。

上記の定義は非常に明確です。データベースはデータの保存に使用され、データベース インスタンスはデータの操作に使用されます。オペレーティング システムの観点から見ると、データベース インスタンスはプロセスとして表され、複数のスレッドに対応します。

非クラスタ データベース アーキテクチャでは、データベースとデータベース インスタンスの間に 1 対 1 の対応関係があります。データベース クラスタでは、1 つのデータベースを操作する複数のデータベース インスタンスが存在する場合があります。つまり、多対 1 の関係です。

2. MySQL スキャフォールド

MySQLは複数のバージョン(MySQL5.5、MySQL 5.6、MySQL 5.7、MySQL 8)を経てきましたが、各バージョンはMySQLに基づいています。

MySQL スキャフォールドには通常、次の主要なモジュール コンポーネントが含まれます。

(1)MySQLは外部対話型インターフェース(コネクタ)を提供する

(2)管理サービスとユーティリティ

(3)接続プール

(4)SQLインターフェース

(5) クエリアナライザコンポーネント(パーサー)

(6)オプティマイザコンポーネント

(7) キャッシュとバッファ

(8)プラガブルストレージエンジン

(9)物理ファイル(ファイルシステム)

(I) MySQLは外部インタラクティブインターフェース(コネクタ)を提供します

コネクタ コンポーネントは、MySQL が提供する対話型コンポーネントです。Java、.net、PHP などの言語では、このコンポーネントを使用して SQL ステートメントを操作し、SQL と対話することができます。

2. 管理サービスとユーティリティ

バックアップ、リカバリ、セキュリティ管理など、MySQL の統合管理を提供します。

(III) 接続プール

クライアントから MySQL サーバーへのさまざまなリクエストを監視し、リクエストを受信し、リクエストをターゲット モジュールに転送する役割を担います。 MySQLサーバーに正常に接続された各クライアントリクエストは

クライアントと MySQL サーバー間の通信、クライアントから送信されたコマンドの受信、サーバーからの結果情報の送信を担当するスレッドを作成または割り当てます。

(IV) SQLインターフェース

DML、DDL、ストアド プロシージャなどのユーザー SQL コマンドを受け取り、最終結果をユーザーに返します。

(V) クエリアナライザコンポーネント (パーサー)

まず、SQL コマンド構文の正当性を分析し、SQL コマンドをデータ構造に分解しようとします。分解に失敗した場合、SQL ステートメントが不合理であることを示します。

(VI) オプティマイザー

標準の手順に従って SQL コマンドを最適化および分析します。

7. キャッシュとバッファ

キャッシュおよびバッファリングコンポーネント

MySQL ストレージエンジン

1. MySQL ストレージ エンジンとは何ですか?

MySQL はリレーショナル データベースであり、リレーショナル データベースの保存はテーブルの形式で行われます。テーブルの作成、データの保存、取得、更新はすべて MySQL によって実行されます。

これはストレージ エンジンによって実行されますが、これは MySQL の MySQL ストレージ エンジンが果たす重要な役割でもあります。

SQL ServerとOracleを学んだ読者は、これら2つのデータベースにはストレージエンジンが1つしかないのに対し、MySQLにはMyISAMストレージなど、より多くの種類のストレージエンジンがあることをご存知かもしれません。

エンジン、InnoDB ストレージ エンジン、およびメモリ ストレージ エンジン。

MySQL に複数のストレージ エンジンがあるのは、MySQL がオープン ソースであるためです。 MySQL ストレージ エンジンは、公式ストレージ エンジンとサードパーティ ストレージ エンジンに大別できます。

スクエアストレージによって発生します。 MySQL はオープン ソースであるため、サード パーティは MySQL フレームワークに基づいてビジネス ニーズに合ったストレージ エンジンを開発できます。

2. MySQLストレージエンジン機能

MySQL ストレージ エンジンは、MySQL で重要な役割を果たします。その役割は主に次の 2 つの側面に要約されます。

機能 1: テーブル作成、データ取得、インデックス作成などを管理します。

機能 2: カスタム ストレージ エンジン開発のニーズを満たします。

3. MySQLエンジンの種類

ストレージ エンジンの種類によって、テーブルを保存する際のストレージ エンジン テーブル メカニズムが異なります。MySQL ストレージ エンジンの種類は、公式ストレージ エンジンとサードパーティ ストレージ エンジンに分けられます。

現在、MyISAMストレージエンジン、InnoDBストレージエンジン、NDBストレージエンジン、アーカイブストレージエンジン、フェデレーテッドストレージエンジン、メモリなど、多くのMySQLストレージエンジンもあります。

ストレージ エンジン、マージ ストレージ エンジン、パートナー ストレージ エンジン、コミュニティ ストレージ エンジン、カスタム ストレージ エンジン、およびその他のストレージ エンジン。

その中で、最も一般的に使用されるストレージ エンジンには、InnoDB ストレージ エンジン、MyISAM ストレージ エンジン、Momery ストレージ エンジンなどがあります。

4. いくつかの代表的なMySQLストレージエンジンの比較

9. 物理ファイル(ファイルシステム)

Linux、Unix、Windows などの、MySQL データベース ファイルと一部のログ ファイルを実際に保存するシステム。

3つの1つのクエリフローチャート

4. 参考文献

[01] MySQL決定版ガイド(米国版) Paul Dubois著、Yang Tao、Yang Xiaoyun、Wang Qun他訳

【02】MySQL テクニカル インサイダー: InnoDB ストレージ エンジン (Jiang Chengyao 著)

【03】SQL学習ガイド(Alan Beaulieu著)

以下もご興味があるかもしれません:
  • MySQLデュアルマスター(マスターマスター)アーキテクチャ構成ソリューション
  • MySQLの論理アーキテクチャに関する深い理解
  • MySQL の全体的なアーキテクチャの紹介
  • MySQL 20 の高性能アーキテクチャ設計原則 (収集する価値あり)
  • MySQL 4 の一般的なマスタースレーブレプリケーションアーキテクチャ
  • MySQL 学習のまとめ: InnoDB ストレージ エンジンのアーキテクチャ設計の予備的な理解
  • Mysql論理アーキテクチャの詳細な説明
  • MySQL データベース アーキテクチャの詳細

<<:  jsはタイトルと説明のキーワードを検出し、見つかった場合は置換するか他のページにジャンプします。

>>:  Linux で cmake を使用して MySQL をコンパイルおよびインストールするための詳細なチュートリアル

推薦する

バッチモードでtopコマンドを実行する方法

top コマンドは、Linux システムのパフォーマンスを監視するために誰もが使用している最適なコマ...

MySQL Limitクエリのパフォーマンスを向上させる方法

MySQL データベース操作では、一部のクエリを実行するときにデータベース エンジンが完全なテーブル...

WeChatアプレットで計算機機能を実装する

この記事は、WeChat アプレットを使用して作成された簡単な計算機です。興味のある方はご覧ください...

ova ファイルを VMware にインポートする際の落とし穴の概要

問題の原因ご存知のとおり、すべてのネットワーク動作は対応するネットワークトラフィックを生成し、すべて...

フェッチネットワークリクエストのカプセル化例の詳細な説明

エクスポートデフォルト({ URL、 メソッド = 'GET'、 データ = nu...

シェルを使用して複数のサーバーでバッチ操作を実行する方法

目次SSHプロトコルパスワード接続プロセスsshツールssh公開鍵ログインバッチ操作複数サーバーファ...

JavaScript parseInt() と Number() の違いのケーススタディ

学習目標: parseInt() と Number() という 2 つの関数は、文字列をデータ型に変...

4種類のMySQL接続とマルチテーブルクエリの詳細な説明

目次MySQL 内部結合、左結合、右結合、外部結合、複数テーブルクエリビルド環境: 1. 内なる慈恩...

Vue バインディング オブジェクト、配列データを動的にレンダリングできないケースの詳細な説明

プロジェクトシナリオ: Dark Horse Vueプロジェクト管理の実践、製品分類の取得、拡張バー...

DIVマスクを使用して、マウスでチェックボックスを直接チェックすることが無効である問題を解決します

フロントエンドの開発過程で、チェックボックスが必要な状況が発生しました。ユーザー操作の利便性を考慮し...

Element UI で自動サイズ調整テキストエリアの高さを設定する方法

Element UIのtextarea input自動サイズに設定すると、テキストボックスのデフォル...

Docker を使用して Go Web アプリケーションをデプロイする方法

目次なぜ Docker が必要なのでしょうか? Docker デプロイメントの例コードの準備Dock...

WEBAPP開発スキルのまとめ(モバイルWebサイト開発の注意点)

1. レスポンシブな Web を開発するには、ページを画面サイズに適応させる必要があります。前の記...

TypeScript名前空間の説明

目次1. 定義と使用1.1 定義1.2 使用2. 複数のファイルに分割する3. エイリアス序文: T...

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

以下に記録されているように、WIN10システムにMYSQLをダウンロードしてインストールするための詳...