Настройка Redis для кеширования сессий 1С-Битрикс
По умолчанию PHP хранит сессии в файлах на диске. При высокой посещаемости или нескольких серверах за балансировщиком это создаёт проблемы: файловая система не масштабируется, а сессии одного пользователя должны попадать на один сервер. Redis решает обе проблемы.
Установка и базовая настройка Redis
Установите Redis и PHP-расширение:
# Ubuntu/Debian
apt install redis-server php-redis
# CentOS/RHEL
yum install redis php-pecl-redis
Базовая конфигурация /etc/redis/redis.conf для сессий:
bind 127.0.0.1
port 6379
maxmemory 256mb
maxmemory-policy allkeys-lru
save "" # отключить персистентность для сессий
Подключение PHP-сессий к Redis
В php.ini или в файле конфигурации сайта:
session.save_handler = redis
session.save_path = "tcp://127.0.0.1:6379?weight=1&timeout=2&prefix=SESS_&database=1"
Параметры save_path: timeout — таймаут подключения в секундах, prefix — префикс ключей для изоляции от других данных, database — номер БД Redis (0–15).
Для Битрикс сессии управляются через /bitrix/php_interface/dbconn.php или bitrix/.settings.php. Лучший способ — задать параметры через конфигурацию веб-сервера для конкретного виртуального хоста, а не глобально в php.ini.
Настройка через .settings.php Битрикс
Битрикс поддерживает кастомные обработчики сессий через session секцию в /bitrix/.settings.php:
'session' => [
'value' => [
'mode' => 'default',
'handlers' => [
'general' => [
'type' => 'redis',
'host' => '127.0.0.1',
'port' => 6379,
'serializer' => \Redis::SERIALIZER_PHP,
'database' => 1,
'ttl' => 86400,
],
],
],
],
Проверка работы
// Проверить, что сессии идут в Redis
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->select(1);
$keys = $redis->keys('SESS_*');
echo count($keys) . ' активных сессий';
Также смотрите redis-cli monitor — в реальном времени показывает операции с Redis. При нормальной работе вы увидите GET SESS_<id> при каждом запросе и SET SESS_<id> при изменении сессии.
Важный нюанс: сессии Битрикс
Битрикс хранит в сессии авторизацию, корзину (для неавторизованных), CSRF-токены. session_write_close() вызывается в конце запроса. Если в обработчике есть блокировки (lock) — при высокой конкурентности одного пользователя запросы выстраиваются в очередь. В большинстве случаев это нормально, но для AJAX-тяжёлых страниц стоит вызывать session_write_close() сразу после чтения данных сессии, если дальнейшая запись не нужна.







