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 関数のコンテキストのルールは何ですか?

推薦する

Tomcat で JNDI データ ソースを構成する 3 つの方法

これまでの仕事では、開発サーバーは一般的にTomcatでした。データソースは、多くの場合、appli...

Nginx レベルで基本的なユーザー認証を構成する手順を完了します。

序文アプリケーション シナリオ: おそらく、内部 Web サイトは外部ユーザーにアクセス可能である必...

FastApi+Vue+LayUIを使用してフロントエンドとバックエンドを分離するサンプルコード

目次序文プロジェクト設計後部フロントエンドプロジェクトを実行する質疑応答序文これまでの API 開発...

Reactはページの透かし効果の全プロセスを実現します

目次序文1. 使用例2. 実施プロセス3. コンポーネントコード要約する序文1. cavans では...

SQL文でのgroup byの使用について簡単に説明します

1. 概要Group by は、by の後の規則に従ってデータをグループ化することを意味します。いわ...

JavaScript の継承についてどれくらい知っていますか?

目次序文コンストラクタ、プロトタイプオブジェクト、インスタンスオブジェクトの関係プロトタイプチェーン...

1 つの記事で Nginx の現在の制限を理解する (簡単な実装)

Nginx は現在、最も人気のあるロード バランサーの 1 つです。インターネット トラフィックの...

CSS で雨滴アニメーション効果を実装するサンプルコード

ガラス窓今日実現するのは雨滴効果です。ただし、雨滴効果を実現する前に、まずは曇りガラス効果を作成しま...

Vueのprops設定の詳細な説明

<テンプレート> <div class="demo">...

el-tree での不完全なテキスト表示の解決策

目次方法1: 水平スクロールバーを設定する最も簡単な方法方法2(新規):ドラッグバーを追加して外側の...

Vueでアイコンをカスタマイズする手順

ant-design-vue は Ali iconfont icons の使用をカスタマイズします\...

MYSQL スロークエリとログ設定とテスト

1. はじめにスロークエリログを有効にすると、MySQL は指定された時間を超えるクエリステートメン...

VMware CentOS 仮想マシンのインストールとネットワーク構成のグラフィックチュートリアル

1. CentOSイメージをダウンロードする1.1 ダウンロードウェブサイトhttp://mirro...

ウェブサイト上のWeiboコンポーネントの再設計の詳細な紹介(写真とテキスト)

前面に書かれたWeibo コンポーネントは、サードパーティのアクセス ユーザーが開発を必要とせずに ...

HTML におけるメタの役割について (インターネットから収集および分類)

W3Cschoolではこのように説明しています<meta> 要素は、検索エンジン向けの説...