Magento PHP cronジョブが必要なPHPファイルを開けない

Magento PHP cronジョブが必要なPHPファイルを開けない

Magento サイトの cron ジョブを設定しようとしています。

このジョブを試してみましたが、うまくいきませんでした:

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

デバッグするには、次のジョブを試しました:

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

その結果、次のエラーが見つかりました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

クローン

<?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);
}

答え1

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

ファイルが見つからないためrequired、エラーが発生しているようです。これらのファイルは にあると思いますか/var/www/html/sitename/app/? この場合は、 の先頭に次の行を追加しますcron.php

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

requireまた、アドレスの先頭にスラッシュを含めるようにステートメントを変更する必要がある場合もあります。

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

答え2

これはまったくの推測ですが、ディレクトリ/ファイルの権限が原因でインクルードが失敗する可能性があります。

cron ジョブを実行しているユーザーが、cron.phpファイルが存在するディレクトリと、そのジョブが開くすべてのファイルにアクセスする権限を持っていることを確認してください。

で実行される Web サーバーの権限を微調整した可能性がありますが、 feユーザーwww-dataから cronjob を実行しています。magento

問題をさらにデバッグするには、環境 ( id -u) と権限 ( )に関する詳細情報を質問に追加することをお勧めします。ls -l /var/www/html/sitename/*

答え3

他の方も述べているように、cron デーモンは正​​常に動作していますが、PHP は cron.php の実行に必要なファイルを見つけることができません。PHP は、php.ini で指定されたインクルード パスと、さらに apache モジュールのドキュメント ルートでこれらのファイルを検索します。そのため、サイト自体は動作します。PHP のコマンド ライン バージョンでは、この追加パスが現在の作業ディレクトリになります。

PHP がドキュメント ルートから実行されるようにすれば、つまり cron を変更して次のコマンドを実行するようにすれば、動作するはずです。

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

関連情報