Grav-plugin-admin: A IU da web diz que "cron não está disponível", mas está funcionando

Criado em 26 ago. 2019  ·  4Comentários  ·  Fonte: getgrav/grav-plugin-admin

Eu configurei minha própria imagem Docker para rodar Grav, mas há apenas um problema que não consigo resolver, e é que a IU da Web diz que o Cron não está disponível, mas ainda parece estar funcionando bem pelo que eu posso dizer.

Este é o aviso que estou tentando corrigir:
Grav - Cron not available

Tenho o crontab em execução no usuário nginx, que parece funcionar muito bem:
Grav - Backups Still Running

Usando a CLI, posso verificar se nginx tem o crontab correto:
Grav - Crontab installed for nginx

E só para ver se isso faria diferença, adicionei-o também ao usuário root:
Grav - Crontab installed for root
... Mas ainda mostra o mesmo aviso na IU da web.

A CLI também mostra que os backups estão sendo executados:
Grav Scheduler

Não tenho certeza do que mais posso fazer para ver se consigo corrigir esse aviso.

Meu Dockerfile:

FROM nginx:stable-alpine
LABEL maintainer="William Miceli <[email protected]>"
USER root

ARG GRAV_VERSION

# Install Dependencies Needed For Grav, With Optional Modules To Help With Performance
RUN apk update && apk add --no-cache \
    dcron \
    php7 \
    php7-curl \
    php7-dom \
    php7-fpm \
    php7-gd \
    php7-json \
    php7-mbstring \
    php7-openssl \
    php7-pecl-apcu \
    php7-pecl-yaml \
    php7-session \
    php7-simplexml \
    php7-xml \
    php7-zip

# Configure NGINX For Grav
ADD https://raw.githubusercontent.com/getgrav/grav/c381bc83040e00c9a8ebe91ac3bda5fe0c217197/webserver-configs/nginx.conf /etc/nginx/conf.d/default.conf
RUN sed -i 's/root \/home\/USER\/www\/html/root \/var\/www/g' /etc/nginx/conf.d/default.conf \
    && sed -i 's/fastcgi_pass unix:\/var\/run\/php\/php7.2-fpm.sock;/fastcgi_pass unix:\/var\/run\/php-fpm.sock;/g' /etc/nginx/conf.d/default.conf \
    && sed -i 's/#listen 80;/listen 80;/g' /etc/nginx/conf.d/default.conf \
    && sed -i '23cuser = nginx' /etc/php7/php-fpm.d/www.conf \
    && sed -i '24cgroup = nginx' /etc/php7/php-fpm.d/www.conf \
    && sed -i '47clisten.owner = nginx' /etc/php7/php-fpm.d/www.conf \
    && sed -i '48clisten.group = nginx' /etc/php7/php-fpm.d/www.conf \
    && sed -i '49clisten.mode = 0660' /etc/php7/php-fpm.d/www.conf \
    && sed -i 's/listen = 127.0.0.1:9000/listen = \/var\/run\/php-fpm.sock/g' /etc/php7/php-fpm.d/www.conf

# Setup Cron
RUN (crontab -u nginx -l; echo "* * * * * cd /var/www;/usr/bin/php bin/grav scheduler 1>> /dev/null 2>&1") | crontab -u nginx -

# Prepare Grav Files
RUN mkdir -p /var/www /usr/src/grav/user \
    && apk add --no-cache ca-certificates \
    && apk add --no-cache --virtual .install-dependencies unzip wget \
    && wget -P /var/www https://github.com/getgrav/grav/releases/download/${GRAV_VERSION}/grav-admin-v${GRAV_VERSION}.zip \
    && unzip -q /var/www/grav-admin-v${GRAV_VERSION}.zip -d /var/www \
    && rm /var/www/grav-admin-v${GRAV_VERSION}.zip \
    && mv -v /var/www/grav-admin/* /var/www \
    && rm -rfv /var/www/grav-admin \
    && apk del .install-dependencies \
    && chown -R nginx:nginx /var/www \
    && mv -v /var/www/user/* /usr/src/grav/user

COPY /entrypoint.sh /

EXPOSE 80
CMD ["/bin/sh", "/entrypoint.sh"]

Git repo

Obrigado pela ajuda!!

evaluating

Comentários muito úteis

A primeira coisa a verificar é com qual usuário o 'servidor da web' é executado em comparação com quando você está no terminal. Se forem usuários diferentes, você terá esse problema. O servidor web só pode verificar o crontab do usuário com o qual está sendo executado. Além disso, a versão PHP é uma 'melhor suposição' que o comando do processo symfony faz ao tentar determinar qual binário PHP usar. Não é inteligente o suficiente para usar uma versão específica como a que você parece ter configurado ( php7 ).

Todos 4 comentários

Além disso, uma coisa pequena que notei, mas não parece fazer qualquer diferença:

CLI diz ter como crontab:
(crontab -l; echo "* * * * * cd /var/www;/usr/bin/php7 bin/grav scheduler 1>> /dev/null 2>&1") | crontab -
Considerando que a IU da Web diz:
(crontab -l; echo "* * * * * cd /var/www;/usr/bin/php bin/grav scheduler 1>> /dev/null 2>&1") | crontab -
(Um é /usr/bin/php7 , o outro é /usr/bin/php )

Não sei se isso importaria para alguma coisa, mas achei melhor mencionar.

A primeira coisa a verificar é com qual usuário o 'servidor da web' é executado em comparação com quando você está no terminal. Se forem usuários diferentes, você terá esse problema. O servidor web só pode verificar o crontab do usuário com o qual está sendo executado. Além disso, a versão PHP é uma 'melhor suposição' que o comando do processo symfony faz ao tentar determinar qual binário PHP usar. Não é inteligente o suficiente para usar uma versão específica como a que você parece ter configurado ( php7 ).

Dentro do meu /etc/nginx/nginx.conf eu tenho:
2019-08-27 21_12_52-Rancher - Brave

Portanto, o usuário do servidor da web parece ser nginx, que tem o crontab definido.

Em algum lugar que eu possa estar faltando?

Também estou obtendo isso em uma instalação do Debian 10 onde tenho meu crontab rodando como root e o servidor web é www-data.

Esta página foi útil?
0 / 5 - 0 avaliações