Linux 上の Docker: コンテナーの自動テストと監視を実行するにはどうすればよいですか?
コンテナ テクノロジーの急速な発展により、Docker は最も人気のあるコンテナ化プラットフォームの 1 つになりました。アプリケーションのデプロイと管理に Docker を使用するプロセスでは、コンテナの自動テストと監視が特に重要です。この記事では、Linux で Docker を使用してコンテナーのテストと監視を自動化する方法を紹介し、対応するコード例を示します。
1. Docker 自動テスト
- Dockerfile の作成
まず、テストするアプリケーションの Dockerfile を作成する必要があります。 Dockerfile は、Docker イメージを構築するための一連の手順が含まれるテキスト ファイルです。以下は簡単な Dockerfile の例です:
FROM python:3.8-alpine WORKDIR /app COPY requirements.txt ./ RUN pip install --no-cache-dir -r requirements.txt COPY . . CMD [ "python", "./app.py" ]
上記の Dockerfile は Python ベースのアプリケーション用に作成され、最初に python:3.8-alpine
イメージに基づいて新しいイメージを構築します。 。次に、作業ディレクトリを /app
に設定し、アプリケーションに必要な依存関係ファイル requirements.txt
をコンテナーにコピーし、依存関係をインストールします。次に、現在のディレクトリ内のすべてのファイルをコンテナにコピーし、CMD
ディレクティブを通じてコンテナの起動時に実行するコマンドを指定します。
- コンテナの構築と実行
Dockerfile の作成が完了したら、次に示すように、docker build
コマンドを使用して Docker イメージを構築できます。 #$ docker build -t myapp:latest .
上記のコマンドは、現在のディレクトリ内の Dockerfile に基づいて
という名前の最新バージョンのイメージを構築します。 次に、
コマンドを使用してコンテナを実行し、以下に示すように、対応するポート マッピングとその他の構成を指定します。 <pre class='brush:php;toolbar:false;'>$ docker run -d -p 8080:8080 --name myapp-container myapp:latest</pre>
上記のコマンドは、
コンテナという名前のコンテナを作成し、コンテナ内の 8080 ポートをホストの 8080 ポートにマップします。
- 自動テストを実行するには、対応するテスト スクリプトを作成する必要があります。 Python を例に挙げると、
- unittest
モジュールを使用してテスト ケースを作成できます。以下に簡単な例を示します。import unittest import requests class TestApp(unittest.TestCase): def setUp(self): self.url = 'http://localhost:8080/' def tearDown(self): pass def test_hello(self): response = requests.get(self.url + 'hello') self.assertEqual(response.status_code, 200) self.assertEqual(response.text, 'Hello, world!') if __name__ == '__main__': unittest.main()
上記の例では、
メソッドを使用してテスト環境を初期化し、tearDown
メソッドを使用します。テスト環境をクリーンアップするために使用されます。 test_hello
メソッドは、requests
ライブラリを使用して HTTP リクエストを送信し、返された結果が期待を満たしているかどうかを判断するためのアサーションを行う特定のテスト ケースです。
- テスト スクリプトの作成が完了したら、ホスト上でテスト スクリプトを実行することで、コンテナ上で自動テストを実行できます。テスト スクリプトが
- test_app.py
として保存されていると仮定すると、次のコマンドを使用してテスト スクリプトを実行できます:$ python test_app.py
2. Docker 監視
Prometheus 監視を使用する
- Prometheus は、Docker エコシステムで広く使用されているオープンソース監視システムです。 Prometheus は、時系列データを収集および保存し、柔軟なクエリおよび視覚化機能を提供することで、コンテナ監視を強力にサポートします。
FROM prom/prometheus:v2.26.0 COPY prometheus.yml /etc/prometheus/
- prometheus.yml
-
global: scrape_interval: 5s scrape_configs: - job_name: 'myapp' static_configs: - targets: ['myapp-container:8080']
上記の設定ファイルでは、
でデータ収集の間隔を指定し、scrape_configs
でデータ収集の間隔を定義します。監視対象。
- Dockerfile と構成ファイルの作成が完了したら、次に示すように、
- docker run
コマンドを使用して Prometheus コンテナを起動できます。$ docker run -d -p 9090:9090 -v /path/to/prometheus.yml:/etc/prometheus/prometheus.yml --name prometheus prom/prometheus:v2.26.0
上記のコマンドは、
という名前のコンテナを実行し、コンテナ内の 9090 ポートをホストの 9090 ポートにマップし、prometheus.yml をマウントします。ホスト上の
ファイルをコンテナーに追加します。
- Prometheus コンテナの起動が完了したら、ブラウザ。このインターフェイスでは、PromQL クエリ言語を通じてデータをクエリし、視覚化できます。
-
概要
この記事では、Linux で Docker を使用してコンテナーのテストと監視を自動化する方法を紹介します。自動テストを実行する場合は、Dockerfile を作成し、コンテナーを構築して実行し、テスト用に対応するテスト スクリプトを作成する必要があります。コンテナーを監視する場合、Prometheus を使用して時系列データを収集および保存し、クエリと視覚化に PromQL を使用できます。上記の方法により、Docker コンテナをより適切に管理および監視し、アプリケーションの安定性と信頼性を確保できます。
参考資料:
Docker 公式ドキュメント: https://docs.docker.com/Prometheus 公式ドキュメント: https://prometheus.io/ docs /以上がLinux での Docker: コンテナーのテストと監視を自動化するには?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Linuxオペレーティングシステムの5つのコアコンポーネントは次のとおりです。1。Kernel、2。Systemライブラリ、3。SystemTools、4。SystemServices、5。FileSystem。これらのコンポーネントは、システムの安定した効率的な動作を確保するために連携し、一緒に強力で柔軟なオペレーティングシステムを形成します。

Linuxの5つのコア要素は、1。Kernel、2。CommandLineインターフェイス、3。ファイルシステム、4。パッケージ管理、5。コミュニティおよびオープンソースです。一緒に、これらの要素はLinuxの性質と機能を定義します。

Linuxユーザー管理とセキュリティは、次の手順を通じて達成できます。1。sudouseradd-m-gdevelopers-s/bin/bashjohnなどのコマンドを使用して、ユーザーとグループを作成します。 2. bulkly forループとchpasswdコマンドを使用して、ユーザーを作成し、パスワードポリシーを設定します。 3.一般的なエラー、ホームディレクトリ、シェル設定を確認して修正します。 4.強力な暗号化ポリシー、定期的な監査、最低限の権限の原則などのベストプラクティスを実装します。 5.パフォーマンスを最適化し、SUDOを使用し、PAMモジュールの構成を調整します。これらの方法により、ユーザーを効果的に管理でき、システムセキュリティを改善できます。

Linuxファイルシステムとプロセス管理のコア操作には、ファイルシステム管理とプロセス制御が含まれます。 1)ファイルシステム操作には、MKDIR、RMDIR、CP、MVなどのコマンドを使用したファイルまたはディレクトリの作成、削除、コピー、および移動が含まれます。 2)プロセス管理には、./my_script.sh&、top、killなどのコマンドを使用して、プロセスの開始、監視、殺害が含まれます。

シェルスクリプトは、Linuxシステムでコマンドを自動実行するための強力なツールです。 1)シェルスクリプトは、通訳を介して行ごとにコマンドを実行して、可変置換と条件付き判断を処理します。 2)基本的な使用法には、TARコマンドを使用してディレクトリをバックアップするなど、バックアップ操作が含まれます。 3)高度な使用には、サービスを管理するための機能とケースステートメントの使用が含まれます。 4)デバッグスキルには、セットXを使用してデバッグモードを有効にし、コマンドが故障したときにセットEを終了することが含まれます。 5)サブシェル、使用、最適化ループを避けるために、パフォーマンスの最適化をお勧めします。

Linuxは、UNIXベースのマルチユーザーのマルチタスクオペレーティングシステムで、シンプルさ、モジュール性、オープン性を強調しています。そのコア機能には、ファイルシステム:ツリー構造で整理され、Ext4、XFS、BTRFSなどの複数のファイルシステムをサポートし、DF-Tを使用してファイルシステムタイプを表示します。プロセス管理:PSコマンドを使用してプロセスを表示し、優先度の設定と信号処理を含むPIDを使用してプロセスを管理します。ネットワーク構成:IPアドレスの柔軟な設定とネットワークサービスの管理、およびsudoipaddraddを使用してIPを構成します。これらの機能は、基本的なコマンドと高度なスクリプト自動化を通じて実際の操作に適用され、効率を向上させ、エラーを削減します。

Linuxメンテナンスモードに入る方法には次のものがあります。1。grub構成ファイルを編集し、「シングル」または「1」パラメーターを追加し、Grub構成を更新します。 2。GRUBメニューでスタートアップパラメーターを編集し、「シングル」または「1」を追加します。終了メンテナンスモードでは、システムを再起動する必要があります。これらの手順を使用すると、必要に応じてメンテナンスモードをすばやく入力して安全に終了し、システムの安定性とセキュリティを確保できます。

Linuxのコアコンポーネントには、カーネル、シェル、ファイルシステム、プロセス管理、メモリ管理が含まれます。 1)カーネル管理システムリソース、2)シェルはユーザーインタラクションインターフェイスを提供します。3)ファイルシステムは複数の形式をサポートします。4)プロセス管理は、フォークなどのシステムコールを通じて実装され、5)メモリ管理は仮想メモリテクノロジーを使用します。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

WebStorm Mac版
便利なJavaScript開発ツール

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SublimeText3 中国語版
中国語版、とても使いやすい

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)
