我的PHP文件不会由cronjob执行

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

我希望我发布在正确的位置,我认为我应该去linux区域,但它可能是一个代码问题。

我有以下PHP脚本:

<?php


use function commands\createWalletsForMain;
use function commands\creditWallet;
use function commands\debitWallet;
use function commands\getConfig;
use function commands\selectAlts;
use function commands\selectMains;
use function commands\updateConfig;
use function commands\selectUncreditedTransactions;
use function commands\selectWallet;
use function commands\updateTransaction;


include_once '../vendor/autoload.php';
include_once '../processors/commands.php';
include_once '../secret/esiConn.php';
include_once '../secret/dbconn.php';

$newConn = createConnection();
$mains = selectMains($newConn);
$uncreditedTransactions = selectUncreditedTransactions($newConn);

use Monolog\Logger;
use Monolog\Handler\StreamHandler;
$log = new Logger('wallet');
$log->pushHandler(new StreamHandler("../processors/logs/wallet.log"));


if($uncreditedTransactions->rowCount() != 0) {
    foreach ($uncreditedTransactions as $row) {
        if(selectWallet($newConn,$row['character_id']) != null) {

            creditWallet($newConn, $row['character_id'],$row['amount']);
            updateTransaction($newConn,$row['transactionID']);
            $log->warning($row['character_id']." credited with ".$row['amount']);
        }
        else
        {
            $log->warning("User has no wallet");
        }
    }
}
else
{
    $log->warning("All transactions credited");
}

if(getConfig($newConn,'ProcessedMonth') == date("m") )
{
    foreach ($mains as $row)
    {
        $totalALTS = selectAlts($newConn,$row['main_id'])->rowCount();
        if(selectWallet($newConn,$row['main_id']) != null) {
            debitWallet($newConn, $row['main_id'], ($totalALTS + 1) * 50000000);
            $log->warning($row['main_id']." has been debited ".(($totalALTS + 1) * 50000000).' isk.');
        }
        else
        {
            $log->warning("User has no wallet");
        }
    }
    updateConfig($newConn,'ProcessedMonth',date('m', strtotime('+1 month')));
}

foreach ($mains as $row) {
    if(selectWallet($newConn,$row['main_id']) == null)
    {
        createWalletsForMain($newConn, $row['main_id']);
        $log->warning('Wallet has been created for '.$row['main_id']);
    }
}
closeConnection();

我在apache2服务器上添加了文件,并在crontab中添加了以下行:

*/3 * * * * /usr/bin/php /var/www/eve/processors/wallet.php

但是它没有执行它,我试图在控制台中手动运行运行qazxsw poi的代码,这确实触发了脚本并且它可以工作。

我有点迷茫....我试图弄清楚它2天....

php ubuntu server cron
1个回答
0
投票

管理解决问题....我的代码实际上是问题。我的include_once穿着原因,因为这些路径永远不应该被声明,现在我已经读过它了。我的错 :)

© www.soinside.com 2019 - 2024. All rights reserved.