Docker コンテナでの標準出力バッファリング: Debian と Ubuntu のケース
Docker コンテナでコードを実行すると、標準出力バッファリングが発生する可能性があります。一部のインスタンスではそうではありません。この問題は、io.MultiWriter を使用して標準出力がコンソールとログ ファイルの両方に送信されるシナリオで発生します。
根本原因: プラットフォームの違い
ルートこの動作の原因は、Debian ベースのイメージと Ubuntu ベースのイメージのプラットフォームの違いにあります。 Debian はデフォルトで stdout をバッファリングするようですが、Ubuntu は stdout を同期的に処理します。
Dockerfile によるデモ
これは、Debian:wheezy と 2 つの Dockerfile に基づく 2 つの Dockerfile を使用して説明できます。もう 1 つは Ubuntu:trusty:
# TRUSTY Dockerfile FROM ubuntu:trusty # ... (rest of the Dockerfile as provided in the problem description) # WHEEZY Dockerfile FROM debian:wheezy # ... (rest of the Dockerfile as provided in the problem description)
Wheeze イメージに基づいてコンテナ内で procwrap を実行すると、バッファされた標準出力が生成されますが、信頼できるイメージに基づいてコンテナ内で実行すると、次の結果が得られます。同期標準出力。ただし、Docker を使用せずに Debian VM で procwrap を実行すると、stdout バッファリングは発生しません。
解決オプション
この問題を解決するには、いくつかのアプローチが検討できます。
最終的には、最適なソリューションは、特定のアプリケーションと動作環境によって異なります。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3