ほとんどの Linux プログラムのデバッグには通常、ログ ファイルの調査が含まれますが、これは複雑なプロセスになる場合があります。ただし、Docker のコンテナ化された環境で実行する場合は、運用環境でアプリケーションをデバッグするために、より具体的なツールを使用する必要があります。 ログはどこに保存されますか?簡単に答えると、Docker はコンテナ ログを主な保存場所である /var/lib/docker/ に保存します。各コンテナには、その ID (通常表示される短縮 ID ではなく完全な ID) に固有のログがあり、次のようにアクセスできます。 ログファイル そこに保存されますが、JSON 形式であるため読みにくく、完全なコンテナー ID を使用する必要があるのは面倒です。 Docker には、それらを表示するための組み込みコマンドが用意されています。 docker ログ -f e4bd48ef3103 ここで、-f フラグはプロンプトを開いたままにして、ファイル内の新しいエントリを「監視」します。また、--tail を使用してファイルを末尾まで追跡したり、--timestamps を使用してログ時間を表示したり、--until および --since を使用して時間に基づいてフィルタリングしたりすることもできます。 Docker Compose を使用する場合は、その中で log コマンドを使用してすべてのログを簡単に表示できます。 docker-compose ログ ただし、多くの用途に役立つ STDOUT と STDERR は、Docker ファイル内の「CMD」で指定されたエントリ ポイントのコンソール出力のみを表示することに気付くでしょう。多くのアプリケーションには専用のログ システムがあり、通常は /var/log/nginx/access.log にログが記録されます。このようなログには、Docker を介してホスト側からアクセスできます。 コンテナ内のアプリケーションからのログを表示するコンテナによっては、これが必要ない場合もあります。たとえば、デフォルトの NGINX コンテナは、ログ検査を簡素化するために Docker ログを STDOUT に送信するように設定されています。これは、ログ ファイルへの /dev/stdout シンボリック リンクを使用して実行されます。コンテナーに同様のものを設定できます。 実行 ln -sf /dev/stdout /var/log/nginx/access.log && ln -sf /dev/stderr /var/log/nginx/error.log ただし、コンテナ内の特定のファイルを表示したい場合は、それが可能です。 Docker には exec -it コマンドが用意されており、実行中の Docker プロセス内で任意のコマンドを実行できます。これを使用すると、Docker コンテナ内のログ ファイルを追跡できます。 docker exec -it e4bd48ef3103 tail -f log.txt これにより、任意のコマンドを実行できるため、 docker exec -it ./bin/bash として起動する限り、journalctl やその他の任意のデバッグ戦略を使用できます。ジャンプして調べたい場合は、実行することもできます。 ホスティング サービスに適した、より永続的なソリューションは、Docker ボリューム マウントを使用することです。 /var/log/nginx のようなディレクトリをホストから見えるボリュームにバインドマウントできます。まず、新しいボリュームを作成します。 docker ボリューム作成 nginx-logs 次のコマンドでコンテナ --mount を実行します。 docker run -d \ --name devtest \ --mount ソース=nginx-logs、ターゲット=/var/log/nginx \ nginx:最新 Docker Compose を使用すると、プロセスを自動化できます。 バージョン: "3.0" サービス: ウェブ: 画像: nginx:最新 ポート: - 「80:80」 ボリューム: - nginx-logs:/var/log/nginx/ ボリューム: nginx ログ: この方法では、ホスト上の任意のログ集約サービスがログファイルを直接取り込むことができます。 Dockerデーモンのログを表示する特定のコンテナ化されたアプリケーションではなく、サーバー上の Docker サービス全体の特定のログを表示する場合は、journalctl ログを表示する必要があります。 sudo journalctl -fu docker.service ほとんどのシステムではここに保存されますが、一部のシステムでは場所が異なります。
Docker がログファイルを保存する場所についての説明はこれで終わりです。Docker がログファイルを保存する場所の詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: Element-UI の Select と Cascader にポップアップ下部アクション ボタンを追加する方法
ページ A、B、C の 3 つがあります。ページ A にはページ B が含まれ、ページ B にはペー...
MySQL ブール値、偽または真を格納つまり、データベースに保存されるブール値は 0 と 1 であり...
最近、モバイルページを制作する際には、レイアウトにインラインブロック要素がよく使われますが、インライ...
Linux のデフォルトの ssh リモート ポートは 22 です。デフォルトのポートは、悪意のある...
目次ルーティングマネージャー背景はじめる問題を解決する方法要約するルーティングマネージャー各ジャンプ...
最近、UTF8 エンコードの中国語 Zen Cart Web サイトをデバッグしているときに奇妙な現...
テーブル パーティショニングは、データベース パーティショニングとは異なります。では、テーブル パー...
zip インストール パッケージをダウンロードします。 MySQL8.0 For Windows z...
現在、このような要件があります。ログインした人がカスタマー サービス担当者である場合、注文は「このカ...
MyISAM ストレージエンジンMyISAM ストレージ エンジンは、書き込みよりも読み取りが多く、...
1. サーバー環境の構成: 1. ディスクパーティションを確認します。最近、あるプロジェクト内のサー...
すりガラス効果がうまく表現されていれば、ページが非常に鮮やかで立体的に見えるようになります。写真に直...
float:左/右/なし; 1. 同じレベルフローティング(1)ブロックレベル要素を同じ行に表示する...
目次データ量匿名マウントと名前付きマウントデータボリュームの場所データ量匿名マウントと名前付きマウン...
以下の質問はすべて InnoDB ストレージ エンジンに基づいています。 1. 最も大きな ID を...