質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Fluentd

Fluentdは、オープンソースのログ収集ツールです。ログの収集方法、ログの記録先などのログデータ処理を柔軟にカスタマイズでき、インプットおよびアウトプットが全てプラグインとして実装されています。

Q&A

解決済

1回答

932閲覧

Fluentdを利用した、Dockerコンテナのログ集約方法

mizu0803

総合スコア9

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Fluentd

Fluentdは、オープンソースのログ収集ツールです。ログの収集方法、ログの記録先などのログデータ処理を柔軟にカスタマイズでき、インプットおよびアウトプットが全てプラグインとして実装されています。

0グッド

0クリップ

投稿2020/06/03 00:57

やりたいこと、不明なことをしたためます。
どなたかお分かりになりましたら、ご教示くださいますと幸いです。

□やりたいこと

Dockerコンテナのログを一か所にまとめたい。
※デフォルトは、/var/lib/docker/containers/<コンテナID>/<コンテナID>-json.log

Dockerコンテナは、アプリの機能で起動するため、運用者は制御できない。

そのため、Dockerコンテナに関するログをすべて取得するために、
ユーザがアプリケーション経由で起動したDockerコンテナのログを一か所にまとめたい。
ホストOSの/var/log/td-agent/docker/docker.logにまとめて出力したい。

□構成

OS  :CentOS7.6
Docker : Version:19.03.9
td-agent : 3.7.1

□試したこと

docker run でコンテナを作成するとき、"--log-driver=fluentd"を付与してコンテナ作成。

Fluentdの設定ファイル(/etc/td-agent/td-agent.conf)は下記の通り。

<source> @type forward <parse> @type json </parse> </source> <filter docker.**> @type parser key_name log reserve_data true <parse> @type json </parse> </filter> <match *> @type file path /var/log/td-agent/docker.log </match>

上記を設定した上で、
①td-agentユニット再起動
②事前に作成したdockerイメージ(--log-driverオプションを付与してrunしたもの)をstart
③/var/log/td-agent/dockerを確認

□できたこと

何かしらのファイル出力はできた。
/var/log/td-agent/docker/buffer.<コンテナID>.log
/var/log/td-agent/docker/buffer.<コンテナID>.log.meta

※正しく出力できているか不明。。

お手数おかけしますが、
ご存じの方、ご教示いただけますと幸いです。。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

matchディレクティブの中に、タイミングを記載することで可決しました。

Fluentdの動きで、
①buffer(ファイルorメモリ)に収集ログをため込む
②outputプラグインに指定した形式・タイミングで出力する

今回は①で状態が止まっていました。
また、②はデフォルトで日次で動くらしいので、matchディレクティブを以下のようにすることで、
分単位で出力できるようになりました。

<match **> @type file path /var/log/td-agent/docker time_slice_format %Y%m%d%H%M time_slice_wait 1m time_format %Y-%d-%m </match>

投稿2020/06/03 04:04

mizu0803

総合スコア9

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問