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

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

実際の開発環境や本番環境では、コンテナを独立して実行することはあまりなく、複数のコンテナを一緒に実行する必要がある場合がよくあります。このとき、コンテナを起動するためにrunコマンドを使い続けると、非常に不便になります。このような場合は、docker-composeが適しています。docker composeを使用すると、コンテナオーケストレーションを実現できます。この記事では、docker-composeの使い方を見ていきます。この記事では、jpress のようなオープンソース Web サイトの展開を例に、docker-compose の使用方法を読者に紹介します。 jpress は WordPress の Java バージョンですが、jpress の実装に注意を払う必要はありません。ここでは、プロジェクトの展開を完了するために、通常のアプリケーションとして扱う必要があります。

準備

ここでは合計 2 つのコンテナーが必要です。

  • トムキャット
  • マイグレーション

次に、jpressのwarパッケージが必要です。warパッケージのアドレス: jpress

もちろん、ここでは jpress は必要ありません。読者は自分の状況に応じて、他の Java プロジェクトを選択したり、簡単な Java プロジェクト デプロイメントを記述したりすることもできます。

Dockerfileの作成

Tomcat コンテナでは、関連する war ファイルをダウンロードする必要があるため、これを行うための Dockerfile を作成します。空のフォルダーに次の内容の Dockerfile を作成します。

tomcatから
https://github.com/JpressProjects/jpress/raw/alpha/wars/jpress-web-newest.war を追加
ローカルのTomcatにWebアプリをインストールします。
実行 cd /usr/local/tomcat/webapps/ \
&& mv jpress-web-newest.war jpress.war

説明する:

  • コンテナはTomcatをベースに作成されます。
  • jpress プロジェクトの war パッケージを tomcat の webapps ディレクトリにダウンロードします。
  • jpress プロジェクトの名前を変更します。

docker-compose.ymlを書く

同じディレクトリに、次の内容の docker-compose.yml を記述します (yml の基礎知識はここでは紹介しません。読者は自分で調べることができます)。

バージョン: "3.1"
サービス:
ウェブ:
建てる: 。
コンテナ名: jpress
ポート:
- 「8080:8080」
ボリューム:
- /usr/local/tomcat/
依存:
-db
デシベル:
画像: mysql
コンテナ名: mysql
コマンド: --default-authentication-plugin=mysql_native_password
再起動: 常に
ポート:
- 「3306:3306」
環境:
MYSQL_ルート_パスワード: 123
MYSQL_DATABASE: jpress

説明する:

  • まず、Web コンテナが宣言され、次に db コンテナが宣言されます。
  • build . は、Web コンテナー プロジェクトのビルド コンテキストが . であることを意味します。つまり、Web コンテナーをビルドするために現在のディレクトリで Dockerfile が検索されます。
  • container_name はコンテナの名前を示します。
  • ポートはコンテナのポート マッピングを指します。
  • ボリュームは、コンテナを構成するデータ ボリュームを表します。
  • Depends_on はコンテナが db コンテナに依存することを意味します。起動時には db コンテナが最初に起動し、その後に web コンテナが起動します。これは単に起動のタイミングです。
  • 2 つのコンテナの順序は、Web コンテナが db コンテナが完全に起動した後にのみ起動することを意味するものではありません。
  • db コンテナの場合、Dockerfile の代わりにイメージを使用してビルドされます。
  • restart はコンテナの再起動戦略を記述します。
  • environmentはコンテナを起動するときの環境変数です。ここでは、データベースのルートユーザーのパスワードが設定され、
  • jpress ライブラリでは、環境設定は辞書と配列の形式で行うことができます。

上記の手順を実行すると、docker-compose.ymlが正常に構成されます。

走る

実行方法はいくつかありますが、究極のコマンドは up です。up コマンドは非常に強力です。イメージの構築、サービスの (再) 作成、サービスの開始、サービス関連のコンテナの関連付けなど、一連の操作を自動的に完了しようとします。ほとんどのアプリケーションはこのコマンドを通じて直接起動できます。デフォルトでは、docker-compose up によって起動されたすべてのコンテナはフォアグラウンドにあり、コンソールにはすべてのコンテナの出力情報が同時に表示されるため、デバッグに非常に便利です。Ctrl-C でコマンドを停止すると、すべてのコンテナが停止します。docker-compose up -d コマンドを使用すると、すべてのコンテナが起動され、バックグラウンドで実行されます。このオプションは通常、実稼働環境に推奨されます。したがって、docker-compose.yml が配置されているディレクトリに移動し、次のコマンドを実行します。

docker-compose を起動 -d

実行結果は次のとおりです。


実行後、docker-compose ps コマンドを通じてコン​​テナが起動したことを確認できます。

初期設定

次に、ブラウザに http://localhost:8080/jpress と入力すると、次のように jpress 構成ページが表示されます。

ガイド ページに従って、データベース接続情報と基本的な Web サイト情報を設定します。



注意: MySQL と Web は両方ともコンテナ内で実行されているため、データベース アドレスを構成するときにループバック アドレスを書き込むことはできません。そうしないと、データベースは Web が配置されているコンテナ内で見つかります。

設定が完了したら、次のコマンドを実行して Web コンテナを再起動します。

docker 再起動 jpress

テスト

以下のように、ブラウザでブログのホームページとバックエンド管理ページを表示します。


他の

コンテナを停止する場合は、次のコマンドを実行します。

docker-compose ダウン

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

以下もご興味があるかもしれません:
  • Dockerコンテナが起動直後に終了する問題を解決する
  • Dockerコンテナとホスト間のデータ相互作用の概要
  • Dockerコンテナのネットワークポート設定プロセスの詳細な説明
  • Docker データボリュームコンテナの作成と使用状況分析
  • Dockerコンテナのデータボリュームの詳細な説明
  • WIN10 システムと Docker 内部コンテナ IP 間の通信方法

<<:  シンプルな虫眼鏡効果を実現するJavaScript

>>:  MySQL の自動増分主キーが使い果たされた場合の対処方法

推薦する

CSSでカスタムフォント(font-face)を導入する方法の詳細な説明

なぜこれを使ったのか?それはポスターを作ることから始まりました。それは嵐の夜でした。 。 。さて、無...

Ubuntu 20.04 ベスト設定ガイド (初心者向け)

1. システム構成1. sudoパスワードをオフにするsudo コマンドを使用するたびにパスワード...

MySQLユーザー権限テーブルについての簡単な説明

MySQL はインストール時に自動的に mysql という名前のデータベースを作成します。mysql...

React NativeのScrollViewプルダウンリフレッシュ効果

この記事では、React Native ScrollViewのプルダウンリフレッシュ効果の具体的なコ...

モバイルデバイス上の 1px 境界線を解決する最善の方法 (推奨)

モバイル デバイス向けに開発する場合、Retina 画面上で要素の境界線が太くなるという問題に遭遇す...

MySQLクエリ最適化: 100万件のデータに対するテーブル最適化ソリューション

1. 2つのクエリエンジン(myIsamエンジン)のクエリ速度InnoDB はテーブル内の特定の行数...

du コマンドを使用して Linux システム ディレクトリのサイズを取得する方法

Linux システムを使用したことがある人なら、Linux システムの ls コマンドは通常、ファイ...

Vue 要素と Nuxt の使用に関するヒントを共有する

1. 要素時間選択提出フォーマット変換例えば 2018年9月7日金曜日 00:00:00 GMT+0...

JavaScript の toLocaleString() での時間フォーマットに関する新しいアイデア

目次1. 時刻表示に関する従来の考え方2. 時刻の書式設定 toLocaleString() Obj...

MySQL でタイムスタンプを日付に変換する例

序文職場で次のような状況に遭遇しました。ログ システムのテーブルでは、時間フィールドには日付データで...

React antd タブの切り替えによりサブコンポーネントが繰り返し更新される

説明する: Tabs コンポーネントが切り替わると、TabPane に含まれる同じサブコンポーネント...

JavaScript でシンプルな Web 時計を実装する

JavaScript を使用して Web ページ クロックを実装します。効果は次の図に示されています...

MySQL に大量のデータを挿入する 4 つの方法の例

序文この記事では主に、MySQLに大量のデータを挿入する4つの方法を紹介し、参考と学習のために共有し...

古典的なJavaScriptの再帰ケースの質問の詳細な分析

目次再帰とは何ですか?また、どのように機能しますか? 1. 合計(1)デジタル加算(2)配列の和2....

JavaScript配列の簡単な紹介

目次配列の紹介配列リテラル2次元配列要約する配列の紹介配列- Arrayもオブジェクトですこれは通常...