Мой вопрос сводится к тому, должны ли несколько процессов magento cron: run -vvv всегда выполняться и постоянно попадать на MySql.
Я настраиваю Magento 2.2.1 через Google Cloud, и у меня есть 3 стандартных задания cron, которые были предварительно настроены через установку Magento в один клик Google.
*/1 * * * * /opt/bitnami/php/bin/php /opt/bitnami/apps/magento/htdocs/bin/magento cron:run -vvv 2>&1
*/1 * * * * /opt/bitnami/php/bin/php /opt/bitnami/apps/magento/htdocs/update/cron.php 2>&1
*/1 * * * * /opt/bitnami/php/bin/php /opt/bitnami/apps/magento/htdocs/bin/magento setup:cron:run -vvv 2>&1
Если посмотреть на top -c, то всегда запущено 2 процесса php.bin, которые постоянно работают с MySql и заставляют его все время использовать около 50-70% ЦП. Вот снимок того, как это обычно выглядит.
PID USER PR NI VIRT RES SHR S %CPU %MEM
19327 mysql 20 0 3872884 332876 19172 S 60.8 3.4 332:42.45 /opt/bitnami/mysql/bin/mysqld.bin --defaults-file=/opt/bitnami/mysql/my.cnf --basedir=/opt/bitnami+
26458 bitnami 20 0 679516 476444 64492 S 24.6 4.9 0:24.85 /opt/bitnami/php/bin/php.bin /opt/bitnami/apps/magento/htdocs/bin/magento cron:run -vvv
26415 bitnami 20 0 677532 475672 64588 R 23.6 4.9 1:36.11 /opt/bitnami/php/bin/php.bin /opt/bitnami/apps/magento/htdocs/bin/magento cron:run -vvv
Я также изменил запуск крон каждые 5 минут, вместо значения по умолчанию каждую минуту, но поведение остается прежним.
Мое последнее изменение менялось каждые 7 минут и 8 минут с помощью 2 cron: запускать задания с интервалом в 3 и 4 минуты, причем одновременно выполнялось только одно задание cron с 30% - 40% ЦП от MySQL.
Мой сайт также не имеет трафика сейчас, потому что я еще не запустил его. Это нормальное поведение от Magento, так как с сайтом ничего не происходит? Я оставил его на 12 часов, ничего не делая, и когда я смотрю сверху, cron все еще работает и забивает MySQL.
ОБНОВЛЕНИЕ: теперь ясно, что проблема заключается только в первом cron: запустить процесс, который вызывает проблемы. Я изменил 2-й и 3-й элементы обратно на каждую минуту и оставил первый на 8-й минуте, и за один раз запущен только один запущенный процесс cron: run. Из комментария ниже это может быть проблема с установками Bitnami Magento, но это мой первый опыт работы с Magento, поэтому я не знаю, является ли это ожидаемым поведением (я действительно надеюсь, что это не так).
htop
. С ней я вижу , что у меня есть больше , чем десять строк сmagento cron:run -vvv
. Некоторые были живы в течение нескольких минут. Я постараюсь выяснить, почему cron не работает так, как ожидалось.