Docker を使用した war パッケージ プロジェクトのデプロイの実装

Docker を使用した war パッケージ プロジェクトのデプロイの実装

Docker で war をデプロイするには、コンテナを使用する必要があります。ここでは tomcact コンテナを使用します。実際には、war パッケージを tomcat の webapps ディレクトリにドロップするだけです。tomcat が起動すると、war パッケージが自動的に解凍されます。

1 つは、Tomcat コンテナ イメージを Docker にインストールし、Tomcat イメージの下の Web アプリに war パッケージをドロップすることです。ただし、Tomcat が閉じられている場合、その Web アプリケーションの下のパッケージは消えます。2 つ目はマウントを使用して、Tomcat コンテナーのイメージをインストールしますが、WAR パッケージを Tomcat の下の Web アプリケーションにドロップせず、外部フォルダーを直接作成し、この外部フォルダーを WABAPPS に関連付けます。これにより、新しく作成されたフォルダーに WAR をドロップすると、Tomcat の Web アプリケーションもマウントされている WAR パッケージを読み取ることができます。

1. tomcatイメージをインストールして起動する

1. docker が起動状態にあることを前提として、docker の下で tomcat イメージを検索します。ここでは、docker を起動する方法と、自動的に起動するように設定する方法については説明しません。

docker 検索 tomcat 

2. 名前でdockerをダウンロードします。docker pull docker.io/tomcat

3. Tomcatを起動する

 docker run -d -p 8088:8080 docker.io/tomcat

-d はバックグラウンドで実行することを意味し、 -p はポート マッピングを意味し、前面の 8088 は外部アクセス ポート (つまり、ローカル IP によって外部に開かれるポート)、背面の 8080 は Docker コンテナー内のポートです。

4. Tomcatが起動しているかどうかを確認します

3. SpringbootプロジェクトをWarパッケージプロジェクトに変換する

私は springboot を使い慣れているので、war パッケージ プロジェクトを作成するのは面倒です。そこで、新しい springboot プロジェクトを作成し、それを war プロジェクトに変更しました。すでに war パッケージ プロジェクトがある場合は、この手順を無視できます。

1. SpringBootプロジェクトを作成します。これについてはここでは説明しません。必要な場合は、別のブログ「SpringBootを簡単に作成して使用する」をお読みください。

2. pom.xmlファイルを変更する

2.1 jarをwarに変更する

2.2 組み込みWebモジュールのTomcatを削除する

2.3 サーブレットの依存関係を追加します。そうしないと、パッケージングでエラーが報告されます。

<依存関係>
  <groupId>javax.servlet</groupId>
	<artifactId>javax.servlet-api</artifactId>
	<バージョン>3.1.0</バージョン>
</依存関係>

2.4 プロジェクトにエイリアスを追加します。ビルド タグの下に、プロジェクト名である finalName を追加します。追加しない場合、プロジェクト名はアーティファクト ID バージョンになり、生成される war パッケージ名もアーティファクト ID バージョン.war になります。ブラウザーでアクセスすると、プロジェクト名が長くなりすぎます。このステップは個人の好みによって異なります

3. スタートアップクラスを変更します。スタートアップクラスはSpringBootServletInitializerを継承します。

4. tomcatコンテナのwebappsの下にwarパッケージを配置し、warパッケージを起動します。

1. アップロードしたwarパッケージを保存するフォルダを作成します。ルートディレクトリに配置します。

mkdir warPackageを実行し、ファイルをこのディレクトリに転送します。

2. warパッケージをTomcatコンテナのwebappsディレクトリにコピーします。

2.1. 実行中のTomcatコンテナのコンテナIDを確認し、docker psを実行する必要があります。

2.2. tomcat コンテナの webapps ディレクトリに war パッケージをコピーします。コマンドの形式は次のとおりです: docker cp xxx.war パッケージ パス コンテナ ID:/コピー先のディレクトリ パス

docker cp /warPackage/dockerProject.war e591e16899c6:/usr/local/tomcat/webapps

2.3. コピーされているかどうかを確認する

dockerでtomcatコンテナに入ります: docker exec -it e591e16899c6 /bin/bash

コンテナを終了する: exit

3. コンテナを再起動します: docker restart + コンテナID

4. ブラウザのアクセス パスは次のとおりです: アクセスしたポート: プロジェクト名/インターフェース名。私のプロジェクト名は dockerProject です。Docker は私が作成したシンプルなコントローラーです。

5. マウントディレクトリを使用してwarパッケージを起動します。

マウントとは、サーバー上に別のディレクトリを作成し、それをTomcatの下のWebアプリケーションのパスにマップして、Tomcatが外部フォルダ内のファイルを読み取ることができるようにすることである。

1. 手間を省くために、上で作成した/warPackageフォルダを直接使用します。

2. ディレクトリをマウントし、Tomcatコンテナを実行して、自動的に再起動するように設定します: --restart=always

docker run -d -p 8088:8080 -v /warPackage/:/usr/local/tomcat/webapps --restart=always docker.io/tomcat

次に、tomcatディレクトリに入ると、すでにwebappsの下にあることがわかります。

3. ブラウザアクセス

Docker を使用して war パッケージ プロジェクトをデプロイする方法についての記事はこれで終わりです。 war パッケージの Docker デプロイに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。 今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Docker を使用してスタンドアロン Pulsar とクラスター化された Redis をデプロイする方法 (開発アーティファクト)
  • アイデアをDockerに接続してワンクリックでデプロイする方法
  • Dockerを使用してMySQL 8.0をデプロイする方法の例
  • Docker を使用した ELK7.3.0 ログ収集サービスの導入に関するベスト プラクティス
  • Docker で onlyoffice をインストールして展開する詳細なプロセス

<<:  JavaScript のよりエレガントなエラー処理方法 async await

>>:  MySQL alter ignore構文の詳細な説明

推薦する

ウェブページ HTML 特殊記号 HTML 特殊文字比較表

特殊記号名前付きエンティティ10進数エンコード特殊記号名前付きエンティティ10進数エンコードアルファ...

仮想マシンを作成し、VMware に Redhat Linux オペレーティング システムをインストールする (グラフィック チュートリアル)

VMware で仮想マシンを作成し、Redhat Linux オペレーティング システムをインスト...

VMwareのCentosシステムでNavicatがMySQLサーバーに接続できない問題を解決します

ホスト 'xxxx' はこの MySQL サーバーに接続できませんエラー: 1130...

JSプロトタイプとプロトタイプチェーンについての簡単な説明

目次1. プロトタイプ2. プロトタイプポインタ: __proto__要約する1. プロトタイプJa...

Vue の双方向イベントバインディング v-model の原理についての簡単な説明

目次説明する:要約する補充するDOM を直接変更して操作する js や jQuery とは異なり、V...

入力タイプ=ファイルスタイルを定義する方法

ファイルコントロールを美しくする理由は何ですか?他の子供たちはみんなきちんとしたきれいな服を着ている...

JavaScript を使用してテーブル情報を追加および削除する

JavaScript 入門JavaScript は軽量なインタープリタ型の Web 開発言語です。言...

Vue カプセル化コンポーネント アップロード画像コンポーネント

この記事の例では、参考のためにvueアップロード画像コンポーネントの具体的なコードを共有しています。...

Momentsで写真を整理するためのCSSコード

まず、Moments を開いて、写真の数が異なるいくつかのレイアウトを確認するか、以下の例を参照して...

CSSプロパティに基づいたボタンホバーボーダーと背景アニメーションのコレクション

ハートの属性不透明度: .999 は要素のスタッキングコンテキストを作成し、ボタン6と8のアニメーシ...

CSS の読み込みによってブロックが発生しますか?

おそらく誰もが js の実行によって DOM ツリーの解析とレンダリングがブロックされることを知って...

Vue でフルスクリーンを実装し、フルスクリーン終了を監視する

目次序文:実装手順:完全なソースコード:詳細情報:序文: vueでは、デフォルトページを実装し、di...

ネイティブ js はカスタム スクロール バー コンポーネントを実装します

この記事の例では、カスタムスクロールバーコンポーネントを実装するためのjsの具体的なコードを参考まで...

Linuxカーネルスケジューラソースコード初期化の分析

目次1. はじめに2. スケジューラの基本概念2.1. 実行キュー (rq) 2.2 スケジューリン...

JD.com フラッシュセール効果を実現する JavaScript

この記事では、JD.comのフラッシュセール効果を実現するためのJavaScriptの具体的なコード...