Устойчивость подключений с помощью Управляемого Redis (предварительная версия)
Повторная попытка выполнения команды
Настройте клиентские подключения, чтобы повторить попытку выполнения команд с экспоненциальным увеличением задержки. Дополнительные сведения см. в руководстве по обработке повторных попыток.
Параметры TCP для клиентских приложений на базе Linux
Параметры TCP по умолчанию в некоторых версиях Linux могут привести к сбою подключений к серверу Redis в течение 13 минут или более. Параметры по умолчанию могут запретить клиентскому приложению обнаруживать закрытые подключения и автоматически восстанавливать их, если подключение не было закрыто корректно.
Сбой повторного обновления подключения может произойти в ситуациях, когда сетевое подключение нарушено или сервер Redis переходит в автономный режим для незапланированного обслуживания.
Рекомендуем следующие параметры TCP:
Параметр | Значение |
---|---|
net.ipv4.tcp_retries2 |
5 |
Дополнительные сведения об этом сценарии см. в разделе Невозможность восстановить подключение в течение 15 минут при работе в Linux. Хотя это обсуждение относится к библиотеке StackExchange.Redis , другие клиентские библиотеки, работающие в Linux, также затронуты. Статья будет полезна и может быть применена к другим библиотекам.
Использование ForceReconnect с StackExchange.Redis
В редких случаях сбой повторного подключения StackExchange.Redis после удаления подключения. В подобных случаях проблему решит перезапуск клиента или создание нового ConnectionMultiplexer
. Мы рекомендуем использовать одноэлементный шаблон ConnectionMultiplexer
, одновременно разрешив приложениям принудительное повторное подключение. Ознакомьтесь с примером проекта быстрого запуска, максимально соответствующим платформе, которую использует ваше приложение. Пример шаблона этого кода см. в наших кратких руководствах.
Пользователи ConnectionMultiplexer
должны будут обработать все ошибки ObjectDisposedException
, которые могут возникнуть в результате удаления старой версии.
Вызовите метод ForceReconnectAsync()
для параметров RedisConnectionExceptions
и RedisSocketExceptions
. Также можно вызвать метод ForceReconnectAsync()
для параметра RedisTimeoutExceptions
, но только если вы используете достаточный ReconnectMinInterval
и ReconnectErrorThreshold
. В противном случае установка новых подключений может привести к каскадному отказу сервера из-за истекшего времени ожидания в результате перегрузки.
В приложении ASP.NET можно использовать интегрированную реализацию в пакете Microsoft.Extensions.Caching.StackExchangeRedis вместо непосредственного использования пакета StackExchange.Redis. Если вы используете Microsoft.Extensions.Caching.StackExchangeRedis в приложении ASP.NET, а не с помощью StackExchange.Redis напрямую, можно задать UseForceReconnect
для свойства значение true:
Microsoft.AspNetCore.Caching.StackExchangeRedis.UseForceReconnect = true
Настройка соответствующего времени ожидания
Для обеспечения устойчивости подключения важно учитывать два значения времени ожидания: время ожидания подключения и время ожидания команды.
Время ожидания подключения
Это connect timeout
время, когда клиент ожидает установления подключения к серверу Redis. Настройте клиентскую библиотеку так, чтобы значение connect timeout
составляло пять секунд. Тогда у системы будет достаточно времени на подключение даже при более высокой загрузке ЦП.
Небольшое connection timeout
значение не гарантирует, что подключение устанавливается в этом интервале времени. Если что-то пойдет не так (высокий коэффициент загрузки ЦП клиента, высокий коэффициент загрузки ЦП сервера и т. д.), небольшой значение connection timeout
подключения приведет к сбою подключения. Такое поведение часто усугубляет и без того плохую ситуацию. Вместо того чтобы сократить время ожидания, более короткие тайм-ауты усугубляют проблему, переводя систему на перезапуск процесса повторного подключения, что может привести к циклу подключение > сбой > повторная попытка.
Время ожидания команды
У большинства клиентских библиотек есть еще одна конфигурация времени ожидания для command timeouts
, которая определяет, сколько времени клиент ожидает ответа от сервера Redis. Мы рекомендуем использовать начальное значение меньше пяти секунд, но можно также выбрать значение command timeout
больше или меньше в зависимости от сценария и размеров значений, хранимых в кэше.
Если значение command timeout
слишком мало, подключение может казаться нестабильным. Однако если значение command timeout
слишком велико, приложению может потребоваться длительное время, чтобы выяснить, не превышено ли время ожидания команды.
Предотвращение пиковых количеств подключений клиента
Избегайте одновременного создания большого количества подключений при повторном подключении после потери подключения, так как новые создания подключений ограничены. Как использование краткого времени ожидания подключения может привести к длительным простоям, так и несколько одновременных повторных попыток подключения могут увеличить нагрузку на сервер и продлить время, необходимое для успешного восстановления подключения всех клиентов.
Если вы повторно подключаетесь ко многим экземплярам клиента, рассмотрите возможность ошеломления новых подключений, чтобы избежать регулирования новых подключений.
Примечание.
При использовании клиентской библиотеки StackExchange.Redis задайте abortConnect
значение false
в строка подключения. Рекомендуется разрешить ConnectionMultiplexer
обрабатывать подключения. Дополнительные сведения см. в рекомендациях StackExchange.Redis.
Закрытие старых подключений
Кэши имеют ограничения на количество клиентских подключений на каждом уровне кэша. Убедитесь, что когда клиентское приложение воссоздает подключения, оно закрывает и удаляет старые соединения.
Период запланированного обслуживания
Настройте параметры кэша с учетом необходимости обслуживания. Дополнительные сведения о создании периода обслуживания для уменьшения негативных последствий для кэша см. в разделе "Канал обновления" и "Расписание обновлений".
Другие конструктивные шаблоны для обеспечения устойчивости
Для обеспечения устойчивости можно применять конструктивные шаблоны. Дополнительные сведения см. в разделе Как сделать приложение отказоустойчивым.
Время ожидания перед переходом в режим простоя
Управляемое redis (предварительная версия) Azure имеет 10-минутное время ожидания для бездействия подключений. Время ожидания 10 минут позволяет серверу автоматически очищать утечки подключений или подключений, потерянных клиентским приложением. Большинство клиентских библиотек Redis имеют встроенную возможность периодически отправлять heartbeat
или keepalive
команды, чтобы предотвратить закрытие подключений, даже если нет запросов от клиентского приложения.
Если есть риск простоя подключений в течение 10 минут, настройте keepalive
интервал в значение менее 10 минут. Если приложение использует клиентскую библиотеку, которая не поддерживает собственные keepalive
функции, ее можно реализовать в приложении, периодически отправляя PING
команду.