Как запустить задание cron в определенное время в Magento 2?

Aug 20 2020

Я хочу создать задание cron, которое обновляет цену продукта, которая отключена, и cron запускается в определенное время 1 раз в день.

Я создал собственный базовый модуль, взяв ссылку из https://www.mageplaza.com/devdocs/magento-2-create-cron-job/

Мой crontab.xml (путь: app / code / Product / Cron / etc / crontab.xml)

<?xml version="1.0" ?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:module:Magento_Cron:etc/crontab.xsd">
<group id="default">
    <job instance="Product\Cron\Cron\Test" method="execute" name="mageplaza_helloworld_cron">
        <schedule>*/1 * * * *</schedule>
    </job>
</group>
</config>

мой test.php

<?php

namespace Cron\Run\Cron; (path : app/code/Product/Cron/Cron/Test.php )

class Test
{

public function execute()
{

    $writer = new \Zend\Log\Writer\Stream(BP . '/var/log/cron.log'); $logger = new \Zend\Log\Logger();
    $logger->addWriter($writer);
    $logger->info(__METHOD__); return $this;

}
}

Но он не показывает мне сообщение в файле cron.log. То, что мне не хватает, приветствуется.

Ответы

1 Msquare Aug 20 2020 at 12:53

Добавьте эти файлы в свой настраиваемый модуль и сначала проверьте, включен ли ваш модуль. Ваш модуль должен быть включен.

Создайте класс для запуска cron

приложение / код / ​​имя поставщика / имя модуля / Cron

Test.php

<?php
namespace VendoreName\ModuleName\Cron;

use Psr\Log\LoggerInterface;

class Test {
    protected $logger; public function __construct(LoggerInterface $logger) {
        $this->logger = $logger;
    }

    public function execute() {
        $this->logger->info('Cron Works');
    }
}

Создайте crontab.xml

app / code / VendoreName / ModuleName / и т. д.

crontab.xml

<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:module:Magento_Cron:etc/crontab.xsd">
    <group id="default">
        <job name="custom_cronjob" instance="VendoreName\ModuleName\Cron\Test" method="execute">
            <schedule>* * * * *</schedule>
        </job>
    </group>
</config>

Скомпилировать и очистить кеш

bin/magento s:up
bin/magento setup:di:compile
bin/magento cache:clean

Проверьте работу cron

На этом шаге показано, как успешно проверить настраиваемое задание cron с помощью SQL-запроса к таблице базы данных cron_schedule.

  1. Запускаем задания Magento cron:
bin/magento cron:run
  1. Введите команду magento cron: run два или три раза.

Когда вы вводите команду в первый раз, она ставит задания в очередь; впоследствии запускаются задания cron. Вы должны ввести команду не менее двух раз.

  1. Запустите SQL-запрос SELECT * из cron_schedule WHERE job_code, например '% custom%'
  1. Убедитесь, что сообщения записываются в системный журнал Magento:
var/www/html/magento_root/var/log/system.log

Нажмите здесь, чтобы узнать больше

Я надеюсь, это поможет вам.