如何将 docker cron 日志写入 stdout/stderr

Asn*_*ari 4 cron stdout docker

我有使用CMD ["cron","-f"]命令运行 cron 的 docker 。这会将输出写入 cron 日志文件。

有什么办法可以将这些日志重定向到控制台。

我的基本图像看起来像

FROM ubuntu:latest
RUN ls

RUN apt-get update
RUN apt install -y software-properties-common
RUN add-apt-repository -y ppa:openjdk-r/ppa
RUN apt-get update
RUN apt-get install -y openjdk-12-jre

RUN apt-get -y install cron wget unzip



RUN wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | apt-key add - \
    && echo "deb http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google-chrome.list \
    && apt-get update -qqy \
    && apt-get -qqy install google-chrome-stable \
    && rm /etc/apt/sources.list.d/google-chrome.list \
    && rm -rf /var/lib/apt/lists/* /var/cache/apt/* \
    && sed -i 's/"$HERE\/chrome"/"$HERE\/chrome" --no-sandbox/g' /opt/google/chrome/google-chrome


ARG CHROME_DRIVER_VERSION=76.0.3809.68
RUN wget --no-verbose -O /tmp/chromedriver_linux64.zip https://chromedriver.storage.googleapis.com/$CHROME_DRIVER_VERSION/chromedriver_linux64.zip \
    && rm -rf /opt/chromedriver \
    && unzip /tmp/chromedriver_linux64.zip -d /opt \
    && rm /tmp/chromedriver_linux64.zip \
    && mv /opt/chromedriver /opt/chromedriver-$CHROME_DRIVER_VERSION \
    && chmod 755 /opt/chromedriver-$CHROME_DRIVER_VERSION \
    && ln -fs /opt/chromedriver-$CHROME_DRIVER_VERSION /usr/bin/chromedriver

COPY tests-cron /etc/cron.d/tests-cron
RUN chmod 0644 /etc/cron.d/tests-cron
WORKDIR /etc/cron.d
RUN ls
RUN crontab /etc/cron.d/tests-cron

RUN touch /var/log/cron.log



WORKDIR /app
RUN mkdir pricetest

COPY --from=maven-container /app/ pricetest/
RUN cp /usr/bin/chromedriver ./pricetest

WORKDIR /app/pricetest
ENV SHELL=/bin/bash

CMD ["cron", "-f"]
Run Code Online (Sandbox Code Playgroud)

PS:这个项目我还在进行中。所以我还没有优化 docker build。

tests-cron我的 cronfile ( ) 包含

* * * * * root echo "Hello world"
Run Code Online (Sandbox Code Playgroud)

使用的基本图像: ubuntu:latest

Adi*_*iii 8

是的,有一种方法可以将日志重定向到控制台,您只需要更改 Dockerfile 的入口点即可。这是基于 alpine 的工作示例,它每分钟运行一次带有输出的 cronjob。

高山形象

CMD 标志

-f  Foreground
-L FILE Log to FILE
Run Code Online (Sandbox Code Playgroud)

文件

-f  Foreground
-L FILE Log to FILE
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

另一件事,请始终共享您的基本图像,以便很容易理解问题的上下文。

Ubuntu 镜像

ubuntu 中的解决方法是替换CMD一点,但我不会推荐这种方法,因为 cron 不会是容器的父进程。您可以在此处此处阅读有关此方法的更多信息

如果要优化,请使用 alpine docker 容器的未来映像,这是这两个映像的大小差异。

Alpine 仅为 5MB,而 Ubuntu 为 91MB

在此处输入图片说明

这是使用基本映像 Ubuntu 输出的 cron 的工作示例

FROM alpine:latest
RUN echo "* * * * * echo hello" | crontab - 
CMD ["crond","-f", "-L", "/dev/stdout"]
Run Code Online (Sandbox Code Playgroud)