Dockerがログファイルを保存する場所の詳細な説明

Dockerがログファイルを保存する場所の詳細な説明

ほとんどの 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

ほとんどのシステムではここに保存されますが、一部のシステムでは場所が異なります。

  • Amazon Linux: /var/log/docker
  • CentOS/RHEL: /var/log/messages | grep docker
  • Apple: ~/Library/Containers/com.docker.docker/Data/log/vm/dockerd.log
  • Windows: AppData\Roaming\Docker\log\vm\dockerd.log

Docker がログファイルを保存する場所についての説明はこれで終わりです。Docker がログファイルを保存する場所の詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Docker コンテナのログを表示およびクリーンアップする方法 (テスト済みで効果的)
  • Dockerコンテナアプリケーションログの表示方法
  • Docker コンテナ ログの中国語文字化け問題の解決方法
  • Dockerコンテナのログ処理の詳細な説明
  • Docker ログが多すぎてディスクがいっぱいになる場合の対処方法
  • Dockerでnginxログをローリングするアイデアの詳細な説明
  • Docker を使用して ELK ログ システムを構築する例
  • dockerログマウントの問題を解決する
  • Dockerコンテナのログ分析

<<:  Element-UI の Select と Cascader にポップアップ下部アクション ボタンを追加する方法

>>:  フロントエンドAIカットのコツ(体験談)

推薦する

MySQL sql99構文の内部結合と非等価結合の詳細な説明

#事例: 従業員の給与水準を照会する 選択 給与、等級 から 従業員 参加する ジョブグレード g ...

CentOS 8 システム FTP サーバーのインストールとパッシブ モードの設定の詳細なチュートリアル

目次1. 基本を理解する2. システム環境を確認する3. ftpコマンドをインストールする[オプショ...

初心者向けのMySQLデータベースとテーブルDDLの作成と操作の学習

目次1. データベースを操作する1.1 データベースを作成する1.2 データベースをクエリする1.3...

CSSの4種類の配置の違いの詳細な説明

フロントエンド開発でよく使われるCSSの配置方法は、位置決めには、通常位置決め、相対位置決め、絶対位...

Linux での mysql および mysql.sock のインストールに関する問題

最近、Linux に Aphace、mysql、php をインストールするときに多くの問題に遭遇しま...

Linux でファイルを削除するさまざまな方法の効率の比較

Linux で大量のファイルを削除する効率をテストします。まず500,000個のファイルを作成する$...

MySQL 匿名ログインでデータベースを作成できない問題の解決方法

よくある質問ユーザー ''@'localhost' によるデータベー...

CSSのoutline-offsetプロパティを使用してプラス記号を実装する

次のような初期コードがあると仮定します。 <!DOCTYPE html> <htm...

MySQL遅延スレーブを導入するメリットのまとめ

序文MySQL のマスター/スレーブ レプリケーション関係は、厳密には「同期」または「マスター/スレ...

テーブルタグ(TAGS)の詳細な紹介

テーブルの基本構文<table>...</table> - テーブルを定義し...

MySQL GTID の総合概要

目次01 GTIDの紹介02 GTIDの仕組み03 GTIDの利点と欠点04 テスト環境構築05 テ...

CSS で水平方向と垂直方向に中央揃えする 10 の方法を教えます (要約)

面接には必需品、仕事でも必ず使います。うーん、誰でも分かるでしょう。これ以上何も言わずに、要約とレン...

MySQL に IP アドレスを効果的に保存する方法と、文字列 IP と数値を変換する方法の詳細な説明

High Performance MySQL バージョン 3 (セクション 4.1.7) を見ると、...

TypeScriptはvscodeを使用してコードのコンパイルプロセスを監視します

インストールtsコマンドをグローバルにインストールする npm install -g typescr...

ReactのPropsの簡単な比較

目次クラスコンポーネントのプロパティ比較浅い同等の浅い比較機能コンポーネントの簡単な比較先週面接に行...