cherednichenkoa / m2-ce-cron
用于替换 Magento 2 Cron 功能的包
Requires
- php: >=7.0.0
This package is not auto-updated.
Last update: 2024-09-12 01:04:50 UTC
README
Cron
本模块为 Magento 2 重写基本 cron 功能,修复已知错误,并提供一个 cron 服务模型以控制 cron 进程执行。
默认的 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
-
登录到您的管理员并设置系统 -> 计划任务设置下的选项
-
如果尚未启用,请在此处启用计划任务: http://devdocs.magento.com/guides/v2.0/config-guide/cli/config-cli-subcommands-cron.html