Наименее ресурсозатратная реализация распределённой блокировки Redis, для которой требуется менее 300 строк кода. Требуется только зависимость spring-data-redis, также можно расширить Jedis самостоятельно. Для использования автоматической сборки springboot достаточно переключиться на версию 1.x.
Идея реализации блокировки основана на повторно входимой блокировке, эта распределённая блокировка поддерживает механизм повторного входа.
Блокировка выполняется как одна атомарная операция. Блокировка может быть снята из-за сбоя Redis или локально. У некоторых может возникнуть вопрос о разнице между этим методом и использованием setNx с истекающим сроком действия (далее — обычный метод). Ниже приводится сравнение:
Клиент 1 получил блокировку на главном узле Redis. Главный узел упал, а асинхронная репликация записи на подчинённый узел ещё не завершена. Подчинённый узел становится главным узлом, и клиент 2 может получить ту же блокировку, что и клиент 1.
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Комментарии ( 0 )