Назад к вопросам
Middle
2
Деплоишь код, с базой всё в порядке, процессор не загружен, но запросы через REST API выполняются последовательно, как будто один за одним. Что может быть не так с конфигурацией подключения к БД?
Компании, где спрашивали
Evrone
Ответ от нейросети
sobes.tech AI
Если запросы через REST API выполняются последовательно, хотя процессор не загружен и база в порядке, вероятная причина — недостаточное количество соединений в пуле подключения к базе данных.
В Node.js часто используется пул соединений для работы с БД. Если пул настроен с минимальным количеством соединений (например, 1), то запросы будут обрабатываться последовательно, ожидая освобождения соединения.
Что проверить и исправить:
- Увеличить размер пула соединений (connection pool size).
- Убедиться, что соединения не блокируются длительными транзакциями.
- Проверить, что запросы к БД выполняются асинхронно и не блокируют event loop.
Пример настройки пула для PostgreSQL с использованием pg:
const { Pool } = require('pg');
const pool = new Pool({
max: 20, // максимальное количество соединений в пуле
idleTimeoutMillis: 30000,
connectionTimeoutMillis: 2000,
});
Если пул слишком маленький, запросы будут ждать своей очереди, что и приводит к последовательному выполнению.