Tomcat Nativeを使用してTomcat IO効率を向上させる方法の詳細な説明

Tomcat Nativeを使用してTomcat IO効率を向上させる方法の詳細な説明

導入

IO には、初期のブロック IO から、非ブロッキング IO、IO 多重化、非同期 IO まで、段階的に IO のパフォーマンスを最大化するためのさまざまな種類があります。

今日はTomcat Nativeを使用してTomcat IOの効率を向上させる方法を紹介します。

Tomcatへの接続方法

コネクタは、Tomcat で外部クライアントとの通信を処理するために使用されます。コネクタは主に、外部クライアントからのリクエストを受け入れ、処理エンジンに転送して処理するために使用されます。

Tomcat には 2 種類のコネクタがあります。 1 つは HTTP コネクタで、もう 1 つは AJP コネクタです。

HTTP コネクタは誰もがよく理解しているはずです。これは Tomcat が使用するデフォルトのコネクタでもあります。

また、AJP と呼ばれるコネクタもあり、これは主に Web サーバーとの通信に使用されます。AJP プロトコルは HTTP よりも高速であるため、他の Web サーバーとの通信に加えて、AJP を使用して Tomcat クラスターを構築することもできます。

どちらの方法も、BIO、NIO、NIO2、APR の 4 つのプロトコルをサポートしています。

#次の 4 つのコネクタ実装はすべて、クライアントからの HTTP 要求を直接処理します。org.apache.coyote.http11.Http11Protocol: HTTP/1.1 プロトコルをサポートするコネクタ。

org.apache.coyote.http11.Http11NioProtocol: HTTP/1.1 プロトコル + New IO をサポートするコネクタ。

org.apache.coyote.http11.Http11Nio2Protocol: HTTP/1.1 プロトコル + New IO2 をサポートするコネクタ。

org.apache.coyote.http11.Http11AprProtocol : APR (Apacheポータブルランタイム)テクノロジーを使用するコネクタ。ネイティブ


#ウェブサーバーを扱うための実装方法は以下の4つです。org.apache.coyote.ajp.AjpProtocol: AJPプロトコルコネクタを使用してウェブサーバー(Apache httpdなど)との通信を実現します。org.apache.coyote.ajp.AjpNioProtocol: SJPプロトコル+新しいIO

org.apache.coyote.ajp.AjpNio2Protocol: SJP プロトコル + 新しい IO2

org.apache.coyote.ajp.AjpAprプロトコル: AJP + APR

それぞれの違いについてお話ししましょう。BIO はブロック IO であり、最も基本的な IO 方式です。次のように設定します。

<コネクタポート="8080" 
プロトコル="HTTP/1.1"
 
最大スレッド数 = "150" 
接続タイムアウト = "20000" 
リダイレクトポート=”8443” />

Tomcat バージョン 7 未満は、デフォルトで bio モードで実行されます。 Tomcat 8.5 以降、Tomcat は BIO のサポートを削除しました。

New IO は、java.nio パッケージとそのサブパッケージに基づいた IO メソッドです。ノンブロッキング IO モードを提供でき、従来の BIO よりも効率的な操作効率を実現します。

新しい IO を次のように構成します。

<コネクタ ポート="8080" プロトコル="org.apache.coyote.http11.Http11NioProtocol"
接続タイムアウト = "20000"
リダイレクトポート="8443" />

New IO と New IO2 の違いは何ですか?

新しい IO2 は、tomcat8 で導入された IO メソッドです。次のように設定できます。

<コネクタ ポート="8080" プロトコル="org.apache.coyote.http11.Http11Nio2Protocol"
接続タイムアウト = "20000"
リダイレクトポート="8443" />

apr メソッドは高度であり、これが今日説明する tomcat ネイティブの主な機能です。

APR と Tomcat ネイティブ

apr の完全な名前は Apache Portable Runtime で、非常に移植性の高いライブラリであり、Apache HTTP Server 2.x の中核です。 APR には、高レベルの IO 機能 (sendfile、epoll、OpenSSL など)、OS レベルの機能 (乱数の生成、システム ステータスなど)、ネイティブ プロセス処理 (共有メモリ、NT パイプ、Unix ソケット) へのアクセスなど、多くの用途があります。

Tomcat は、JNI の形式で Apache HTTP サーバーのコア ダイナミック リンク ライブラリを呼び出して、ファイルの読み取りやネットワーク転送操作を処理できるため、静的ファイルの Tomcat の処理パフォーマンスが大幅に向上します。

APR を使用すると、次の機能が得られます。

  • 非ブロッキング I/O と要求接続の維持。
  • OpenSSL および TLS/SSL をサポートします。

Tomcat Native は、Tomcat が APR を使用できるようにするライブラリです。

したがって、Tomcat Native を使用するための前提条件は、APR ライブラリ、OpenSSL、および JDK をインストールすることです。

apr と openssl は次の方法でインストールできます。

Debian ベースの Linux システム:

apt-get で libapr1.0-dev と libssl-dev をインストールします。

rpm ベースの Linux システム:

yum インストール apr-devel openssl-devel

Windows では、tcnative は dll の形式で提供されており、直接ダウンロードして使用することができます。

ただし、Linux ではプラットフォームが異なるため、tcnative を Linux で独自にコンパイルする必要があります。

一般的に、tcnative のソース パッケージは bin/tomcat-native.tar.gz にあります。解凍してください。

まず configure コマンドを実行します。

./configure --with-apr=/usr/bin/apr-1-config \
  --with-java-home=/home/jfclere/JAVA/jdk1.7.0_80/ \
  --with-ssl=はい\
  --prefix=$CATALINA_HOME

次に、make 操作を実行します。

作成 && インストール

生成された lib ファイルは $CATALINA_HOME/lib に配置されます。

tomcat で APR を使用する

tcnative をインストールすると、Tomcat で APR を使用できるようになります。

まず、conf/server.xml に次の構成があるかどうかを確認します。

<リスナークラス名="org.apache.catalina.core.AprLifecycleListener" SSLEngine="オン" />

次に、$CATALINA_HOME/bin/setenv.sh を変更して、tc-native lib ファイルを LD_LIBRARY_PATH に追加する必要があります。

LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$CATALINA_HOME/lib
LD_LIBRARY_PATHをエクスポートする

最後に、APR 接続を追加します。

<コネクタ ポート="8080" プロトコル="org.apache.coyote.http11.Http11AprProtocol"
接続タイムアウト = "20000"
リダイレクトポート="8443" />

ただ実行するだけです。

ログから次のことがわかります。

org.apache.catalina.core.AprLifecycleListener の初期化

情報: APR ベースの Apache Tomcat ネイティブ ライブラリ 1.xy がロードされました

org.apache.catalina.core.AprLifecycleListener の初期化

情報: APR 機能: IPv6 [true]、sendfile [true]、accept フィルター [false]、ランダム [true]。

org.apache.coyote.http11.Http11AprProtocol の初期化

これは、APR がインストールされ、使用されていることを示します。

Tomcat Native を使用して Tomcat IO 効率を向上させる方法についての記事はこれで終わりです。Tomcat Native を使用して Tomcat IO 効率を向上させる方法の詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • ネイティブ APR モードで Tomcat をインストールおよび構成するチュートリアル
  • Tomcatのサーバーオプションの詳細な説明
  • Tomcat 起動エラー: java.util.zip.ZipException の解決方法
  • Linux サーバーで Tomcat の BIO、NIO、APR モードを設定する方法
  • Tomcatはセッション共有(セッションレプリケーション)を実装します

<<:  MySQLコンテナ間のレプリケーション構成例の詳細な説明

>>:  JavaScript 関数のコンテキストのルールは何ですか?

推薦する

Dockerコンテナオーケストレーション実装プロセス分析

実際の開発環境や本番環境では、コンテナを独立して実行することはあまりなく、複数のコンテナを一緒に実行...

WeChatアプレットコンポーネントライフサイクルの落とし穴の記録

通常、コンポーネントのライフサイクルは、ビジネス ロジックが始まる場所です。ビジネスシナリオが複雑で...

Vueプロジェクトはログインと登録の効果を実現します

この記事の例では、ログインと登録の効果を実現するためのvueプロジェクトの具体的なコードを共有してい...

Vue の一般的な問題と解決策の概要 (推奨)

Vue に限定されず、他の種類の SPA プロジェクトにも当てはまる問題がいくつかあります。 1....

Ubuntu で起動時に自動的に起動するシェル スクリプトを作成する (推奨)

スクリプトを書く目的は、さまざまなサービスを手動で起動しなくて済むようにすることです(怠惰のためでも...

Vueは画像のズームとドラッグをサポートするリッチテキストエディタを統合しています

必要:ビジネス要件によると、写真をアップロードできる必要があり、アップロードされた写真はモバイル端末...

Reactにおけるコンテキスト適用シナリオの分析

コンテキストの定義と目的コンテキストは、コンポーネント ツリーにプロパティを明示的に渡すことなく、コ...

Ubuntu 19にTheanoをインストールする際の問題を解決する

解決: pythearn2 パッケージをダウンロードしたディレクトリで、setup.py ファイルを...

Vue での bimface の使用に関する詳細

目次1. Vue スキャフォールディングをインストールする2. プロジェクトを作成する3.1 プロジ...

MySQL複合インデックスの詳細な研究

複合インデックス (結合インデックスとも呼ばれます) は、複数の列に対して作成されるインデックスです...

Node+Express テストサーバーのパフォーマンス

目次1 テスト環境1.1 サーバーハードウェア1.1.1 t2.マイクロ1.1.2 c5.large...

JSキャンバスは描画ボードと署名ボードの機能を実現します

この記事では、お絵かきボード/サインボード機能を実現するためのJSキャンバスの具体的なコードを参考ま...

Linux の 5 ステップ ビルド カーネル ツリー

目次0. システムに付属するカーネルツリー1. 環境設定最初のステップステップ2 2. ソースコード...

vue keepAlive キャッシュクリア問題事例の詳細な説明

Keepalive は Vue プロジェクトでのキャッシュによく使用され、基本的な要件を満たすのに非...

Linuxでのaliasコマンドの使い方の詳細な説明

1. 別名の使用alias コマンドは、コマンドのエイリアスを設定するために使用されます。このコマン...