Mysqld は MySQL サーバーのメインプロセスであり、mysqld は MySQL の真のコアであると言え、すべての作業は mysqld プロセスを中心に実行されます。したがって、巨大な mysql を分析するには、mysqld のコードが最良の突破口となります。
すべてはおなじみの main() 関数から始まります。実際には、mysqld_main() 関数から始まります。これらのコードはすべて mysqld.cc にあります。次に、mysqld_main() は win_main)() を呼び出します。 win_main() 関数は主に初期化作業を行います。
初期化作業が完了すると、MySQL は接続を受け入れる準備が整います。次に、主人公の Handle_connections_methods() 関数が表示されます。この関数の主な仕事は、TCP/IP、名前付きパイプ、共有メモリの 3 つの方法で接続を受け入れる 3 つの新しいサブプロセスを作成することです。通常の状況では、お客様は最も柔軟な通信方法である TCP/IP (ソケット) を使用して MySQL サーバーに接続します。ただし、組み込みソフトウェアのアプリケーション環境では、後者の 2 つの通信方式を使用する必要があります。
簡略化された handle_connections_methods() 関数:
static void handle_connections_methods() { mysql_mutex_lock(&LOCK_thread_count); mysql_cond_init(key_COND_handler_count, &COND_handler_count, NULL); handler_count=0; handler_count++; mysql_thread_create(key_thread_handle_con_namedpipes, &hThread, &connection_attrib, handle_connections_namedpipes, 0)); handler_count++; mysql_thread_create(key_thread_handle_con_sockets, &hThread, &connection_attrib, handle_connections_sockets_thread, 0)); handler_count++; mysql_thread_create(key_thread_handle_con_sharedmem, &hThread, &connection_attrib, handle_connections_shared_memory, 0)) while (handler_count > 0) mysql_cond_wait(&COND_handler_count, &LOCK_thread_count); mysql_mutex_unlock(&LOCK_thread_count); }
3 つの新しいスレッドを作成した後、handle_connectins_methods() 関数は長いループに入り、3 つの接続スレッドがすべて終了するまで終了しません。ここでは主にソケット接続スレッドを調べます。この handle_connections_sockets_thread です。このスレッドは自身を初期化した後、handle_connections_sockets();
を直接呼び出しました。 handle_connections_sockets() 関数は、select() を使用して mysqld のリスニング ポートを呼び出し、クライアントが接続するのを待ちます。クライアントが接続すると、この関数内で新しい THD タイプの変数が作成されます。この変数は、接続の確立から SQL 構文分析、クエリの実行、結果の返しなどに至るまでの「ソーシャル バタフライ」です。この変数は常に存在しており、要するに非常に重要な変数です。
コマンドの転送ステーションである構造体 st_vio もあります。 vio タイプの構造は、「Social Butterfly」THD でも定義されています。この構造体の機能は、通信内容をストレージ ソケットから読み取り、その値を THD の vio 変数に割り当てることです。 VIO タイプは、リクエストの内容、時刻、リクエストのソケット アドレスなど、リクエストを詳細に記述します。次に行われるのは、この「ソーシャル バタフライ」をサービス スレッドに渡し、create_thread_to_handle_connection() がこの関数を実装することです。
以下は削除されたコードです
void create_thread_to_handle_connection(THD *thd) { if (cached_thread_count > wake_thread) { mysql_cond_signal(&COND_thread_cache); } else { mysql_thread_create(key_thread_one_connection, &thd->real_id, &connection_attrib, handle_one_connection, (void*) thd))); } }
この関数は、アイドル状態のキャッシュ スレッドがあるかどうかを確認します (MySQL は、切断直後にサービス スレッドを破棄しませんが、キャッシュ スレッドがあればそれを使用します)。存在しない場合は、新しいスレッドが作成されてサービスを提供します。繋がり。この時点で、接続はサービス スレッドに入り、接続スレッドは戻って接続を待ち続けます。
以下の内容はすべてサービス スレッドに実装されています。「MySQL の詳細」に非常に詳細なコード トレースが記載されています。興味のある学生は参照してください。参考のために関数呼び出しシーケンスを添付しました。
りー
以上がMySQLサーバー接続プロセスの説明と分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。