Tomcatのデフォルトパスの設定によって発生するプロジェクトURLの競合を解決する方法の詳細な説明

Tomcatのデフォルトパスの設定によって発生するプロジェクトURLの競合を解決する方法の詳細な説明

序文

Tomcat は優れた Java コンテナですが、避けられない小さな落とし穴もいくつかあります。ここでそれらを記録しておきます。

始める

質問

  • 複数のプロジェクトをデプロイした後の URL パスの競合

シナリオの説明

1. webapps には、projectA と projectB という 2 つのプロジェクトがあります。管理情報インターフェースを除き、他の 2 つのプロジェクトにはセキュリティ検証メカニズムがあります。

2. projectA はフロントエンドとバックエンドに分離されていないため、Java プロジェクト内にも静的リソースが存在します。静的リソースでインターフェース要求を行う場合、パッケージ名は書き込まれません。たとえば、ログインする場合、js コードはサーバーの IP + ポート + 現在設定されている URL (/login) を連結しますが、/login の前に /projectA を追加しません。したがって、ローカルマシンでのテストでは問題はなく、このような問題はデプロイ時にのみ発生します。これも問題であり、以下で解決します。

3.projectBは通常通り実行中のプロジェクトです

シナリオ2の解決策

Tomcat で設定ファイルを開き、<Host> タグに <Context> を追加して、それをサーバーのデフォルトのアクセス パスとして設定します。これにより、パッケージ名を回避できますが、この方法は非常に非公式であり、推奨されません。

<ホスト名="localhost" appBase="webapps"
      unpackWARs="true" autoDeploy="true">

    <!-- SingleSignOn バルブ、Web アプリケーション間で認証を共有
       ドキュメント: /docs/config/valve.html -->
    <!--
    <Valve クラス名="org.apache.catalina.authenticator.SingleSignOn" />
    -->

    <!-- アクセス ログはすべての例を処理します。
       ドキュメント: /docs/config/valve.html
       注: 使用されるパターンは、pattern="common" を使用するのと同じです -->
    <Valve クラス名="org.apache.catalina.valves.AccessLogValve" ディレクトリ="logs"
        プレフィックス="localhost_access_log" サフィックス=".txt"
        パターン="%h %l %u %t &quot;%r&quot; %s %b" />
    <コンテキスト パス="" docBase="/usr/tomcat8.6/webapps/sc_edu" デバッグ="0" リロード可能="true"/>

  </ホスト>

コードの説明

<コンテキスト パス="" docBase="/usr/tomcat8.6/webapps/sc_edu" デバッグ="0" リロード可能="true"/>
  • path と doBase を一緒に使用すると、指定されたパッケージ パスが示されます。簡単にするために、docBase を直接アンインストールできます。
  • tomcat を再起動し、パッケージ内のリソースに ip+port で直接アクセスできることをテストします。ただし、他のパッケージ内のリソースにアクセスすると、URL のあいまいさが発生します。当初は projectB にアクセスしたかったのですが、projectA にマップされていました。このような問題が発生するのは一部の URL のみです。

そこで、別のTomcatをインストールし、直接パスマッピングを必要とするプロジェクトのみをデプロイするという解決策があります。

これにより、Tomcatが配置されているディレクトリに戻り、cpコマンドでコピーされます。

$> cp -r tomcat8.5/ tomcat8.6/

次に、tomcat8.5 の projectA を tomcat8.6 に移動します。

tomcat8.5を削除します

<コンテキスト パス="" docBase="/usr/tomcat8.6/webapps/sc_edu" デバッグ="0" リロード可能="true"/>

tomcat8.6 では、service.xml に次の変更を加える必要があります。

tomcat8.5 と異なり、ポートが競合しない限り、シャットダウンに対応するポートを 8006 に変更します。

<サーバーポート="8006" シャットダウン="シャットダウン">

リクエストに対応するポートを変更します。原理は上記と同じです

<コネクタ ポート="8081" プロトコル="HTTP/1.1"
        接続タイムアウト = "20000"
        リダイレクトポート="8443" />

<Host> タグの内容がコピーされ、対応するマッピング パスに変更する必要があります。

この方法では、2 つの Tomcat を同時に実行することができ、起動とシャットダウンは互いに影響を及ぼしません。

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

以下もご興味があるかもしれません:
  • Tomcat での jar のロードに関する異常な問題の分析と解決
  • Apache、Tomcat、Nginx サーバーの詳細な理解と比較分析
  • Linux で Tomcat を実行するいくつかの方法の説明
  • Tomcat 7.0 で仮想ディレクトリを設定し、仮想パスを構成する方法
  • IDEAリモートデバッグを使用したTomcatの説明
  • TomcatはLog4jを使用してcatalina.outログを出力します。
  • Tomcat でのコネクタ構成
  • Tomcatのデフォルトプログラム公開パスの使用と変更についての説明
  • Eclipse プロジェクトを IDEA にインポートし、Tomcat にデプロイするための詳細な手順
  • Tomcat サーバーが tomcat7w.exe を開けない場合の解決策

<<:  MySQL 5.7.18 のダウンロードとインストールの詳細な手順

>>:  Mysql 5.7.18 MySQL proxies_priv を使用して同様のユーザーグループ管理を実装する

推薦する

MySQL 8.0.11 Community Green Edition の Windows 用インストール手順図

このチュートリアルでは、インストールに最新の MySQL コミュニティ グリーン バージョンである ...

MySQL の条件文で 1 つの情報しか読み取れない問題に対する 2 つの解決策

今日、私の同僚が MYSQL クエリ ステートメントの作成時に非常に奇妙な問題に遭遇しました。MyS...

MySQLの共通関数の概要

序文: MySQL データベースは、よく使用される集計関数、日付および文字列処理関数など、幅広い関数...

JavaScript の for/of、for/in の詳細な紹介

目次JavaScriptでは、 forループを記述する一般的な方法がいくつかあります。最初の、そして...

JavaScriptを使用して独自のAjax関数を定義する

ネイティブJSによって開始されたネットワークリクエストは、クエリ文字列の形でサーバーに送信されるため...

Docker 起動時の ES メモリ オーバーフローの解決方法

jvm.options ファイルを elasticsearch 構成に追加し、スタック サイズを変更...

js のマクロタスクとマイクロタスクについての簡単な説明

目次1. JavaScriptについて2. JavaScript イベントループ3. マクロタスクと...

MySQL 2級コンピュータ試験共通テストポイント 8つのMySQLデータベース設計最適化方法

MySQLデータベース設計の8つの最適化方法の詳細は次のとおりです。 1. 最も適切なフィールド属性...

CocosCreatorでリストを作成する方法

CocosCreator バージョン: 2.3.4 Cocos には List コンポーネントがない...

Centos7 システム上の nginx サーバーで Phalcon 環境を構築する方法の詳細な説明

この記事では、centos7 システムの nginx サーバーの下に phalcon 環境を構築する...

CentOS 6 および 7 での MySQL 5.7 の詳細なインストール チュートリアル

開発には常にデータが必要です。サーバーとしての Linux では、テスト データを格納するためのデー...

react-navigation6.xルーティングライブラリの基本的な使い方の詳しい説明

目次react-nativeプロジェクトの初期化react-nativeプロジェクトをインストールす...

HTMLチェックボックス説明テキストをクリックして状態を選択/チェック解除します

Web 開発では、チェックボックスは小さく、ユーザーにとって操作があまり便利ではないため、ユーザーが...

CSS3は三角形の連続拡大効果を実現します

1. CSS3の三角形は特殊効果でズームし続けます11.1 画像プレビュー 11.2 index.h...

Vue で video.js を使用して m3u8 形式のビデオを再生する方法

目次1. インストール2. videojsの紹介3. コンポーネントでのテストと使用1. 基本的な自...