cron job can not run laravel schedule on godaddy server - laravel

I'm trying to build a laravel scheduler to save my data history. I create a command "MisReportBackup". then I add it in the kernel too.
protected $commands = [
'\App\Console\Commands\MisReportBackup',
];
my schedule function is
protected function schedule(Schedule $schedule)
{
$schedule->command('MisReportBackup:MisReport')->dailyAt('16:59');
}
then i create a cron job on server
59 16 * * * cd /home/public_html/outpace-erp-v1.1 && php artisan schedule:run >> /dev/null 2>&1
it's 17:13:58(SGT) but did not work yet.

There's no need to specify the schedule for the cron job. For Laravel's scheduler to work, it has to run every minute.
* * * * php /home/public_html/outpace-erp-v1.1/artisan schedule:run >> /dev/null 2>&1
See the documentation.

* * * * * /usr/local/bin/php /home/technolive/public_html/outpace-erp-v1.1/artisan schedule:run > /dev/null 2>&1
it's work.

Related

Run Task Scheduling, Laravel

I have a Task Scheduling with works if I run the manual command : php artisan word:weeklyUpdate , but this must be done automatilcally on a specific date, so I tried to run * * * * * cd /var/www/html && php artisan schedule:run >> /dev/null 2>&1 but I get Command 'app' not found, did you mean:
Kernel.php
protected function schedule(Schedule $schedule)
{
$scheduler = new LkpSchedulerUpdateDate;
$scheduler = $scheduler->first()->toArray();
$schedule->command('word:weeklyUpdate')->weeklyOn($scheduler['date'], $scheduler['time']);
}
UPDATE:
ON sudo php artisan schedule:run I get "No scheduled commands are ready to run."
The command for my case was:
* * * * * php -d register_argc_argv=On /var/www/html/artisan schedule:run >> /dev/null 2>&1

Laravel Telescope Schedule not worked on localhost(mac)

I want test laravel telescope on mac localhost
protected function schedule(Schedule $schedule)
{
$schedule->command('inspire')
->everyMinute();
}
and
* * * * * cd /Users/Jon/Desktop/laravel && php artisan schedule:run >> /dev/null 2>&1
We didn't find anything - just empty space.
but not worked on my system
>> /dev/null redirects standard output (stdout) to /dev/null, which discards it.
So you cannot find anything.
You can add output to a file:
$schedule->command('inspire')->everyMinute()->appendOutputTo($filePath);
or
* * * * * cd /Users/Jon/Desktop/laravel && php artisan schedule:run >> /tmp/file.txt

My Schedular is not calling everyMinute()

My schedular is not calling automatically after every minute.
I have tried following code
protected function schedule(Schedule $schedule)
{
$schedule->command('timestamp:minute')->everyMinute();
}
I need that my schedular will call automatically.
in your terminal, type crontab -e and add below line at the end
* * * * * /usr/bin/php{php_version} /path_to_project/artisan schedule:run >> /dev/null 2>&1
Now, in terminal, go to your project directory and run once
php artisan schedule:run

CronJob is not execute my Laravel application scheduled functions I setup on Amazon EC2 instance

my crontab script
* * * * * php /var/www/html/{project_folder}/artisan schedule:run 1>> /dev/null 2>&1
projectfolder>app>console>kernel.php
protected function schedule(Schedule $schedule)
{
$schedule->command('appointment:get')
->everyMinute();
}
I set this above crontab script to run every minutes. But it's not run.
You've got an extra "1" in your cron schedule. It should be
* * * * * php /var/www/html/{project_folder}/artisan schedule:run >> /dev/null 2>&1

Configure crontab to execute Laravel Task Scheduling

I set this on my cron file
* * * * * php artisan schedule:run >> /dev/null 2>&1
I have this in my Kernel.php
<?php
namespace App\Console;
use Carbon;
use Illuminate\Console\Scheduling\Schedule;
use Illuminate\Foundation\Console\Kernel as ConsoleKernel;
class Kernel extends ConsoleKernel
{
/**
* The Artisan commands provided by your application.
*
* #var array
*/
protected $commands = [
\App\Console\Commands\Inspire::class,
];
/**
* Define the application's command schedule.
*
* #param \Illuminate\Console\Scheduling\Schedule $schedule
* #return void
*/
protected function schedule(Schedule $schedule)
{
$now = Carbon\Carbon::now('America/New_York');
$dt = Carbon\Carbon::parse($now);
$time_start = $dt->toTimeString();
$dt = str_replace('-','_',$dt);
$dt = str_replace(' ','_',$dt);
$dt = str_replace('/',':',$dt);
$schedule->exec('curl '.env('APP_URL').'fbwifi/acl_update')->everyMinute()
->sendOutputTo(public_path().'/tasks/log_'.$dt.'.txt');
}
}
If I manually run
php artisan schedule:run
I got
Running scheduled command: curl http://localhost:8888/fbwifi/acl_update > '/Applications/MAMP/htdocs/code/site/portal/public/tasks/log_2016_10_21_14:01:33.txt' 2>&1 &
and I see the file to be the log file generated perfectly fine.
Then, I wait another 5 mins, I don't see anything else. I am supposed to get five more logs generated.
Did I do anything wrong ? How do I check this ?
Instead of having php artisan schedule:run in cron, create a shell script:
#!/bin/bash
/full/path/to/php /full/path/to/artisan schedule:run >> /tmp/debug.log 2>&1
In your crontab, place the full path to this shell script.
Your crontab runs every minute. If you want to it every 5 minutes, use this:
*/5 * * * * /home/user/myshellscript.sh
You can then examine /tmp/debug.log for errors.
If you do not want a bash scipt, try this in crontab:
*/5 * * * * /full/path/to/php /full/path/to/artisan "schedule:run" >> /tmp/debug.log 2>&1

Resources