O trabalho cron do Magento PHP não consegue abrir os arquivos php necessários

O trabalho cron do Magento PHP não consegue abrir os arquivos php necessários

Estamos tentando configurar o cron job para o site Magento.

Tentamos este trabalho, mas não funcionou para nós:

*/5 * * * * php -f /var/www/html/sitename/cron.php

Para depurar, tentamos este trabalho:

*/5 * * * * /usr/bin/php  -q /var/www/html/sitename/cron.php > 
/var/www/html/sitename/cron-temp.log 2>&1

Como resultado, encontramos esses erros em cron-temp.log:

PHP Warning:  require(app/bootstrap.php): failed to open stream:
 No such file or directory in /var/www/html/sitename/cron.php on line 30

    PHP Fatal error:  require(): Failed opening required 'app/bootstrap.php' 
(include_path='.:/usr/share/php:/usr/share/pear') in /var/www/html/sitename
/cron.php on line 30

cron.php

<?php


// Change current directory to the directory of current script
chdir(dirname(__FILE__));

require 'app/bootstrap.php';
require 'app/Mage.php';

if (!Mage::isInstalled()) {
    echo "Application is not installed yet, please complete install wizard first.";
    exit;
}

// Only for urls
// Don't remove this
$_SERVER['SCRIPT_NAME'] = str_replace(basename(__FILE__), 'index.php', $_SERVER['SCRIPT_NAME']);
$_SERVER['SCRIPT_FILENAME'] = str_replace(basename(__FILE__), 'index.php', $_SERVER['SCRIPT_FILENAME']);

Mage::app('admin')->setUseSessionInUrl(false);

umask(0);

$disabledFuncs = explode(',', ini_get('disable_functions'));
$isShellDisabled = is_array($disabledFuncs) ? in_array('shell_exec', $disabledFuncs) : true;
$isShellDisabled = (stripos(PHP_OS, 'win') === false) ? $isShellDisabled : true;
$isShellDisabled = true;

try {
    if (stripos(PHP_OS, 'win') === false) {
        $options = getopt('m::');
        if (isset($options['m'])) {
            if ($options['m'] == 'always') {
                $cronMode = 'always';
            } elseif ($options['m'] == 'default') {
                $cronMode = 'default';
            } else {
                Mage::throwException('Unrecognized cron mode was defined');
            }
        } else if (!$isShellDisabled) {
            $fileName = basename(__FILE__);
            $baseDir = dirname(__FILE__);
            shell_exec("/bin/sh $baseDir/cron.sh $fileName -mdefault 1 > /dev/null 2>&1 &");
            shell_exec("/bin/sh $baseDir/cron.sh $fileName -malways 1 > /dev/null 2>&1 &");
            exit;
        }
    }

    Mage::getConfig()->init()->loadEventObservers('crontab');
    Mage::app()->addEventArea('crontab');
    if ($isShellDisabled) {
        Mage::dispatchEvent('always');
        Mage::dispatchEvent('default');
    } else {
        Mage::dispatchEvent($cronMode);
    }
} catch (Exception $e) {
    Mage::printException($e);
    exit(1);
}

Responder1

PHP Fatal error:  require(): Failed opening required 'app/bootstrap.php' 
(include_path='.:/usr/share/php:/usr/share/pear')

Parece que seus requiredarquivos não podem ser encontrados e por isso está gerando o erro. Presumo que esses arquivos estejam em /var/www/html/sitename/app/? Neste caso adicione a seguinte linha no início do seu cron.php:

set_include_path('/var/www/html/sitename/');

Você também pode precisar modificar suas requiredeclarações para incluir uma barra no início do endereço:

require '/app/bootstrap.php';
require '/app/Mage.php';

Responder2

Este é um palpite realmente estranho, mas a inclusão pode estar falhando devido às permissões de diretório/arquivo.

Certifique-se de que o usuário para o qual você está executando o cron job tenha todos os direitos para acessar o diretório onde cron.phpo arquivo está e todos os arquivos que ele abre.

Você pode ter ajustado as permissões do servidor da web executado em www-data, mas está executando o cronjob do magentousuário fe.

Você pode adicionar mais informações à sua pergunta sobre o ambiente ( id -u) e as permissões ( ls -l /var/www/html/sitename/*) para depurar ainda mais o seu problema.

Responder3

Como outros mencionaram, seu daemon cron está funcionando corretamente, mas o PHP está tendo problemas para encontrar os arquivos necessários que o cron.php requer para ser executado. O PHP procura por eles nos caminhos de inclusão especificados por php.ini e adicionalmente na raiz do documento para o módulo Apache, portanto, é por isso que o próprio site funciona. Para a versão de linha de comando do PHP, esse caminho adicional é o diretório de trabalho atual.

Deve funcionar se você garantir que o PHP seja executado a partir da raiz do documento, ou seja, altere o cron para executar o comando da seguinte maneira:

*/5 * * * * cd /var/www/html/sitename && php -f /var/www/html/sitename/cron.php

informação relacionada