Tomcatの全体構造の簡単な紹介

Tomcatの全体構造の簡単な紹介

Tomcat は Web コンテナとして広く知られています。Java を学び始めたときから現在の仕事に至るまで、私のプログラミング キャリア全体にわたって Tomcat が付き添ってきました。 Tomcat は本質的にはサーブレット コンテナです。サーブレットが実行できることは、要求リソースを処理し、クライアントの応答オブジェクトに入力することです。

Tomcat は、作成した Servlet クラスをロードし、Servlet の init() メソッドを呼び出し、リクエストに対して servletRequest および servletResponse インスタンスを作成し、Servlet の service() メソッドを呼び出し、servletRequest および servletResponse をパラメータとして渡し、Servlet を閉じるときに destroy() を呼び出して Servlet をアンインストールする役割を担っています。次に、Tomcat の全体構造について簡単に紹介します。

Tomcatの全体構造

図に示すように、Tomcat の 2 つの主要コンポーネントはコネクタとコンテナです。複数のコネクタとコンテナがサービスを形成します。サービスは外部にサービスを提供するために使用され、サービスのライフサイクルはサーバーによって制御されます。サーバーは最上位レベルの抽象化に属します。

コネクタは、ソケット接続、リクエストのカプセル化、接続スレッド プールなど、ネットワーク接続に関連する処理を処理するために使用されます。コンテナは主にコネクタによって受け入れられた要求を処理します。サービスはコネクタとコンテナの周囲の追加レイヤーにすぎず、これらをまとめて外部にサービスを提供します。サービスには複数のコネクタを設定できますが、コンテナは 1 つしか設定できません。すべてのコンポーネントのライフサイクルは、init、start、stop、destroy メソッドを含むライフサイクル インターフェイスを使用して均一に管理されます。

元のコネクタは BIO モードにしか設定できませんでした。現在、高レベルの Tomcat バージョンのデフォルトの接続モードは NIO であり、リクエストの同時実行性が大幅に向上しています。

Tomcat には、上から順に、エンジン、ホスト、コンテキスト、ラッパーの 4 種類のコンテナーがあります。ラッパーはサーブレット、コンテキストはアプリケーション、ホストはサイト、エンジンはエンジンに相当します。コンテナは 1 つだけです。コンテナ間の起動は、

Tomcat コンテナ モデル

今回はTomcatの全体構造について簡単に紹介しました。次にTomcatリクエストの処理フローを通して理解を深めていきます。リクエストがhttp://localhost:8080/test/index.jspであると仮定すると、Tomcatの処理フローは次のようになります。

1. 要求はポート 8080 に送信され、コネクタによって受信されます。

2. コネクタは、処理のために要求をサービスのエンジンに渡し、エンジンが応答するのを待ちます。

3.エンジンはリクエストアドレスを取得し、仮想ホストホストと照合します。

4. エンジンは、リクエスト/test/index.jspを受信するlocalhostという名前のホストを照合し、ホストが所有するコンテキストと一致させます。

5. ホストはコンテキストをパス /test と一致させます。一致するものが見つからない場合は、空のコンテキストによって処理されます。

6. コンテキストはrequest/index.jspを取得し、マッピングファイル内の対応するサーブレットを探します。

7. コンテキストは、パターン *.jsp とサーブレットを照合し、対応する JspServlet クラスを見つけます (Jsp は最終的に Servlet に変換されます)

8. httpservletrequest および httpServletResponse オブジェクトを構築し、それらをパラメータとして使用して JspServlet の doGet または doPost を呼び出します。

9.contextはホストに応答を返す

10. ホストはエンジンに応答を返す

11. エンジンはコネクタに応答を返す

12. コネクタはユーザーのブラウザに応答を返し、リクエストは終了します。

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

以下もご興味があるかもしれません:
  • Pythonはパイプラインを使用してRedisのバッチ読み取りと書き込みを行います
  • Python: Scrapy フレームワークでのアイテム パイプライン コンポーネントの使用に関する詳細な説明
  • パイプラインを使用して Java で Redis バッチを読み書きする方法の詳細な説明 (hmset と hgetall)
  • パイプライン(PipeLine)とバッチ(Batch)操作を使用したRedisの大幅なパフォーマンス向上の詳細な説明
  • Scrapyカスタムパイプラインクラスは、収集したデータをMongoDBに保存する方法を実装します。
  • セマフォによるTomcatの異常終了の解決方法
  • Tomcat パイプライン モードのパイプラインとバルブの詳細な説明

<<:  Java は Excel から MySQL にデータをインポートします

>>:  Linux で履歴コマンドを表示および実行する方法

推薦する

MySQL 8.0 redo ログの詳細な分析

目次序文REDOログの生成REDOログ送信REDOログの保存と通知ユーザースレッドに通知要約する序文...

Web デザイン: Web ミュージックの実装テクニック

<br />Web ページに音楽を挿入する場合、サフィックスに応じて異なるコードを記述す...

Centos 7 mysql-8.0.19-1.el7.x86_64.rpm-bundle.tar の簡単な分析

Baiduクラウドディスク:リンク: https://pan.baidu.com/s/1hv5rUW...

要素のel-tree複数選択ツリー(チェックボックス)親子ノードの関連付けが関連付けられていません

属性チェック-厳密公式ドキュメントでは、チェックボックスが表示されるときに親項目と子項目を互いに関連...

ブラウザが登録できるイベントの概要

HTML イベント リスト一般イベント: onClick HTML: マウスクリックイベント。主にオ...

Vue+express+Socketでチャット機能を実現

この記事では、チャット機能を実現するためのVue+express+Socketの具体的なコードを参考...

JavaScript を使用して動的な QQ 登録ページを作成する

目次1. はじめに1. 基本レイアウト2. 写真を自動的に切り替える3. コンテンツを追加する4. ...

Linux システムに Zookeeper サービスをインストールする方法

1. /usr/local/services/zookeeper フォルダを作成します。 mkdir...

MySQL データベースのバックアップをスケジュールするいくつかの方法 (包括的)

目次1. データをバックアップするためのmysqldumpコマンド2. 一般的なmysqldump操...

Web Storage APIの使用に関する簡単な説明

目次1. ブラウザのローカルストレージ技術1.1、セッションストレージ1.2、ローカルストレージ2....

MySQL PHP 構文の簡単な分析

まずcharAt関数の基本的な構文を見てみましょう文字 = str.charAt(インデックス) c...

1時間で学ぶMySQLの基礎

目次MySQL を使い始めるMySQL 管理6. MySQL サーバーを起動および停止します。 7....

HTML の空リンク href="#" と href="javascript:void(0)" の違い

# には位置情報が含まれます。デフォルトのアンカーは #top で、これは Web ページの上部です...

W3C チュートリアル (11): W3C DOM アクティビティ

ドキュメント オブジェクト モデル (DOM) は、プログラムがドキュメントのコンテンツ、構造、およ...

Dockerデータのバックアップとリカバリプロセスの詳細な説明

データのバックアップ操作は非常に簡単です。次のコマンドを実行します。 docker run --vo...