Búfer estándar en contenedores Docker: un caso de Debian vs. Ubuntu
Al ejecutar código en un contenedor Docker, el almacenamiento en búfer estándar puede ocurrir en algunos casos pero no en otros. Este problema se observa en un escenario en el que la salida estándar se dirige tanto a la consola como a un archivo de registro mediante io.MultiWriter.
Causa principal: diferencias de plataforma
La raíz La causa de este comportamiento radica en las diferencias de plataforma entre las imágenes basadas en Debian y las imágenes basadas en Ubuntu. Debian parece almacenar en búfer la salida estándar de forma predeterminada, mientras que Ubuntu maneja la salida estándar sincrónicamente.
Demostración con Dockerfiles
Esto se puede ilustrar usando dos Dockerfiles, uno basado en Debian:wheezy y el otro en 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)
La ejecución de procwrap en el contenedor en función de la imagen de sibilancias da como resultado una salida estándar almacenada en el búfer, mientras que la ejecución en el contenedor en función de la imagen confiable da como resultado salida estándar sincrónica. Sin embargo, ejecutar procwrap en una máquina virtual Debian sin Docker no muestra almacenamiento en búfer estándar.
Opciones de resolución
Para resolver este problema, se pueden considerar varios enfoques:
En última instancia , la mejor solución depende de la aplicación específica y del entorno operativo.
Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.
Copyright© 2022 湘ICP备2022001581号-3