Оптимизация работы агентов 1С-Битрикс

Наша компания занимается разработкой, поддержкой и обслуживанием решений на Битрикс и Битрикс24 любой сложности. От простых одностраничных сайтов до сложных интернет магазинов, CRM систем с интеграцией 1С и телефонии. Опыт разработчиков подтвержден сертификатами от вендора.
Предлагаемые услуги
Показано 1 из 1 услугВсе 1626 услуг
Оптимизация работы агентов 1С-Битрикс
Средняя
~1-2 недели
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1173
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    811
  • image_bitrix-bitrix-24-1c_development_of_an_online_appointment_booking_widget_for_a_medical_center_594_0.webp
    Разработка на базе Битрикс, Битрикс24, 1С для компании Development of an Online Appointment Booking Widget for a Medical Center
    564
  • image_bitrix-bitrix-24-1c_mirsanbel_458_0.webp
    Разработка на базе 1С Предприятие для компании МИРСАНБЕЛ
    745
  • image_crm_dolbimby_434_0.webp
    Разработка сайта на CRM Битрикс24 для компании DOLBIMBY
    655
  • image_crm_technotorgcomplex_453_0.webp
    Разработка на базе Битрикс24 для компании ТЕХНОТОРГКОМПЛЕКС
    976

Оптимизация работы агентов 1С-Битрикс

Оптимизация агентов Битрикс: диагностика и настройка фоновых задач

Агенты в Битрикс — это PHP-функции, которые платформа запускает по расписанию. Звучит просто, пока не обнаруживаешь, что сайт тормозит каждые 30 секунд, все страницы отдаются медленнее на 500–800 мс именно в момент хита агентов, а в b_agent накопилось 400+ записей, половина из которых — зависшие задачи со статусом ACTIVE = Y и NEXT_EXEC в прошлом.

Стандартная схема запуска агентов через веб-запросы (hitAgent) — это архитектурный компромисс Битрикс, который работает приемлемо на небольших сайтах и становится проблемой на нагруженных проектах. Каждый входящий HTTP-запрос может стать «жертвой», на которую вешается выполнение агентов, блокируя ответ пользователю на время работы фоновой задачи.

Диагностика текущего состояния

Первое, что делаем — смотрим реальную картину в таблице агентов:

SELECT NAME, ACTIVE, NEXT_EXEC, LAST_EXEC,
       TIMESTAMPDIFF(MINUTE, LAST_EXEC, NOW()) AS minutes_since_last
FROM b_agent
WHERE ACTIVE = 'Y'
ORDER BY NEXT_EXEC ASC;

Агенты с NEXT_EXEC в прошлом на несколько часов или дней — это зависшие задачи. Они постоянно пытаются запуститься, занимают слот выполнения и блокируют остальные агенты в очереди.

Второе — смотрим на время выполнения тяжёлых агентов. Если агент поиска (CSearchIndex::IndexAgent) выполняется 45 секунд, а настроен на запуск каждую минуту — он никогда не завершается корректно и запускается повторно до окончания предыдущего экземпляра.

Третье — профилируем влияние агентов на время ответа страниц. Включаем Битрикс-панель отладки или логируем время через \Bitrix\Main\Diag\Debug::startTimeLabel / stopTimeLabel в init.php.

Перевод агентов на cron

Это самое важное изменение. В файле /bitrix/.settings.php или через административный интерфейс (Настройки → Производительность):

'agents' => [
    'value' => [
        'pull_agent_manager' => 'cron',
    ],
],

В crontab добавляем:

*/1 * * * * /usr/bin/php -f /var/www/bitrix/bitrix/modules/main/tools/cron_events.php > /dev/null 2>&1

После перевода на cron агенты больше не выполняются в контексте веб-запросов. Время ответа страниц выравнивается, исчезают характерные «провалы» на графике latency каждые N секунд.

Важный нюанс: агент поиска CSearchIndex::IndexAgent при работе через cron может конкурировать с PHP-FPM за CPU. Выносим его в отдельный cron-скрипт с nice -n 10 и ограничением по времени через timeout.

Оптимизация очереди и приоритетов

После перевода на cron разбираем накопившийся долг:

Чистка зависших агентов. Агенты с NEXT_EXEC старше суток и без успешного LAST_EXEC за последние 48 часов — кандидаты на деактивацию или пересоздание. Для каждого разбираемся: модуль живой? Функция существует? Есть ли исключение в логах?

Оптимизация интервалов. CSearchIndex::IndexAgent с интервалом 30 секунд при реальном времени выполнения 20 секунд — расписание на катастрофу. Пересчитываем интервалы исходя из реального времени работы + буфер 50%.

Разнесение тяжёлых агентов. Если несколько тяжёлых агентов (синхронизация с 1С, отправка email-рассылок, пересчёт цен) настроены на запуск одновременно — разносим их старт через NEXT_EXEC с интервалом 5–10 минут.

Мониторинг выполнения. Добавляем логирование в кастомные агенты:

function MyHeavyAgent(): string
{
    $start = microtime(true);
    // ... логика ...
    $elapsed = microtime(true) - $start;
    if ($elapsed > 10) {
        \Bitrix\Main\Diag\Debug::writeToFile(
            "MyHeavyAgent took {$elapsed}s",
            '',
            '/bitrix/logs/agent_performance.log'
        );
    }
    return 'MyHeavyAgent();';
}

Тяжёлые системные агенты: что с ними делать

CSearchIndex::IndexAgent — индексация поиска. На каталоге 50 000+ товаров может работать часами. Решение: ограничить количество элементов за один запуск через параметр SEARCH_ELEMENT_COUNT в настройках модуля поиска, или перейти на Elasticsearch и отключить встроенный поиск.

CEventMessageAgent — отправка email. Если используется встроенная почта Битрикс без очереди — при накоплении тысяч писем агент зависает. Решение: настроить SMTP через PHPMailer-совместимый транспорт или перейти на Unisender/SendPulse API с очередью.

CBitrixCloudBackupAgent — облачный бэкап. Может занимать всё I/O сервера при больших объёмах. Переносим на ночное время, добавляем ограничение скорости через ionice.

CTaskNotifications::agent (Битрикс24) — уведомления CRM. При большом объёме задач выполняется долго. Разбиваем на пакеты через параметр лимита в теле агента.

Настройка мониторинга агентов

Добавляем в Zabbix/Prometheus метрику количества зависших агентов:

SELECT COUNT(*) as stuck_agents
FROM b_agent
WHERE ACTIVE = 'Y'
  AND NEXT_EXEC < DATE_SUB(NOW(), INTERVAL 1 HOUR);

Если значение > 0 на протяжении более 30 минут — алерт в Telegram/Slack. Это ранний индикатор проблем с cron или перегрузки сервера.

Результат

Перевод на cron и оптимизация очереди агентов убирают периодические просадки времени ответа, снижают нагрузку на БД в пиковые моменты на 20–40%, обеспечивают предсказуемое выполнение фоновых задач без влияния на пользовательские запросы.