Cron 不在 PHP Docker 容器中运行

问题描述 投票:0回答:3

我正在使用

php:7.4-fpm
Docker 映像,我正在尝试设置 cron 来运行,但它没有运行。

这是我的 Dockerfile:

FROM php:7.4-fpm

# Set working directory
WORKDIR /var/www

# Install dependencies
RUN apt-get update && apt-get install -y \
    cron \
    build-essential \
    libpng-dev \
    libjpeg62-turbo-dev \
    libfreetype6-dev \
    locales \
    libzip-dev \
    libmcrypt-dev \
    libonig-dev \
    zlib1g-dev \
    zip \
    jpegoptim optipng pngquant gifsicle \
    vim \
    unzip \
    git \
    graphviz \
    curl \
    supervisor

# Install Imagick
RUN apt-get update && \
    apt-get install -y libmagickwand-dev --no-install-recommends && \
    pecl install imagick && \
    docker-php-ext-enable imagick

# Clear cache
RUN apt-get clean && rm -rf /var/lib/apt/lists/*

# Install extensions
RUN docker-php-ext-install pdo_mysql zip exif pcntl

# Permissions for Laravel
RUN chown -R www-data:www-data /var/www
RUN chmod -R 777 /var/www

# Copy crontab file to the cron.d directory
COPY ./docker/php-server/crontab /etc/cron.d/crontab

# Give execution rights on the cron job
RUN chmod 0644 /etc/cron.d/crontab

# Apply cron job
RUN crontab /etc/cron.d/crontab

# Create the log file to be able to run tail
RUN touch /var/log/cron.log

EXPOSE 9000

CMD bash -c "cron && php-fpm"

当我进入容器并检查

/etc/cron.d/crontab
的内容时,它是正确的

* * * * * php /var/www/artisan schedule:run >> /var/log/cron.log 2>&1
# An empty line

但它没有运行。我不确定这里发生了什么..

当我运行

service cron status
时,它说
[ ok ] cron is running.
但什么也没发生。

php docker cron dockerfile containers
3个回答
4
投票

所以我终于解决了这个问题。我不知道为什么复制 cron 文件不起作用。我还是不知道为什么。 (也许比我聪明的人可以解释一下)。但我通过将命令附加到

/etc/crontab
文件中非常简单地解决了这个问题,现在它可以工作了。

附注crontab 文件需要在末尾添加一个新行字符,因此使用

echo
自动添加它。

这是我更新的 Dockerfile(我删除了复制 crontab 的所有其他行):

RUN echo "* * * * * root php /var/www/artisan schedule:run >> /var/log/cron.log 2>&1" >> /etc/crontab

# Create the log file to be able to run tail
RUN touch /var/log/cron.log

0
投票

我有同样的错误,通过在托管 docker 容器的机器上设置 cron 而不是容器本身来修复。

所以 cron 条目翻译成类似:

* * * * * docker exec web php artisan schedule:run >> storage/logs/cron.log 2>&1

如果您遇到 tty 分配问题,请尝试使用

docker exec -it


-1
投票

您在 /etc/cron.d/crontab 中错过了用户名:

* * * * * php /var/www/artisan schedule:run >> /var/log/cron.log 2>&1

它就在这里:

RUN echo "* * * * * root php /var/www/artisan schedule:run >> /var/log/cron.log 2>&1" >> /etc/crontab
© www.soinside.com 2019 - 2024. All rights reserved.