cherednichenkoa/m2-ce-cron

用于替换 Magento 2 Cron 功能的包

安装次数: 3,411

依赖项: 0

建议者: 0

安全: 0

星标: 0

关注者: 2

分支: 45

类型:magento2-module

1.2.7.6-stable 2019-02-05 16:32 UTC

README

MageMojo

Cron

本模块为 Magento 2 重写基本 cron 功能,修复已知错误,并提供一个 cron 服务模型以控制 cron 进程执行。

Version 1.2.7

默认的 cron 可能会重叠并填充 cron_schedule 表,这可能导致每个 cron 间隔运行的任务呈指数级增加,直到最后 cron 持续运行且永远不会完成。大量 cron 任务也可能导致托管 Magento 2 的服务器崩溃。

本模块用接受作业的服务替换了 cron 管理。作业被安排后,它们将由该服务执行。如果一个作业正在运行,并且另一个具有相同作业代码的作业被拾取,则新作业会被标记为错过。防止重复作业运行,以减少服务器负载。

将默认的 cron 视为一个突然出现并运行任何数量任务的工厂。如果这些任务在下一个 cron 间隔之前未完成,它们会继续处理,但另一个工厂会自发地出现并运行另一组作业,这些作业可能与原始工厂重叠。

本模块通过拥有一个单一来源的服务来处理作业,避免重叠作业的可能性。有一个工厂一直在工作,以确保完成您的作业。

除了服务模型之外,还进行了许多其他增强。例如,重新编写了左连接更新语句,该语句在 cron_schedule 上强制进行全表扫描以获取历史记录。由于它正在从它尝试更新的同一表中读取,因此语句会锁定。

在版本 1.1 中,将 Cron 报告添加到管理员界面,以显示作业代码统计信息和列出 cron 运行错误。

贡献

请参阅 CONTRIBUTING.md

优势

  • 加快 cron 执行速度。

  • 停止数据库锁定。

  • 防止 cron 历史记录爆炸。

  • 防止 cron 进程相互超载。

  • 在系统处于可配置的负载条件下时停止 cron 运行。

  • 设置同时 cron 进程的最大数量。

  • 设置历史记录的数量。

管理员选项

Cron 启用 - 打开或关闭 cron。

最大 Cron 进程数 - 并行运行的 cron 线程数。此选项是所有定义作业的总和。例如:如果您有 5 个作业设置为午夜运行,最大 Cron 进程数设置为 1,则只有一个作业将依次执行,直到所有 5 个都完成。默认为 3。

PHP 二进制名称/路径 - 您在 shell 中运行的 PHP 二进制文件名。通常是 php 或 php70。您可以可选地包括二进制文件的完整路径。默认 php。您还可以在此处添加内联选项,例如 php -dmemory_limit=8096M,如果您想有自定义的 ini 值。

最大负载平均 - 由php函数sys.getloadavg() / CPU核心数定义。sys.getloadavg()函数报告每个正在使用的核心为1.0,就像top中报告的负载平均一样。CPU核心数从/proc/cpuinfo中获取,并将负载平均除以这个数字。例如:如果您有8个核心并且正在使用6个,则返回0.75。如果您的最大负载平均为0.76,则cron将不会运行。当您的负载平均降至0.74时,cron将运行。任何已安排运行但未运行的计划任务将运行。如果同一个计划任务多次错过,则最近的任务将运行,其余的将标记为错过。默认值为0.75(可用CPU的75%)。

历史保留 - 在cron_schedule表中保留的历史天数。默认1(1天)。

Composer安装

  • 在您的终端中运行以下命令
composer require cherednichenkoa/m2-ce-cron
php bin/magento module:enable MageMojo_Cron
php bin/magento setup:upgrade
php bin/magento setup:di:compile
php bin/magento setup:static-content:deploy

许可证

License: MIT