Redis实现分布式锁

栏目: 数据库 · 发布时间: 5年前

内容简介:问题:因为操作不是原子性的,如果在进行setnx的时候,刚好服务器宕机,没有来得及进行expire,那么该key将一直无法释放。直接使用redis的原子命令:
  1. 首先使用setnx命令,即当没有key存在的时候,才会创建value。

    • 当执行成功的时候会返回1

    • 当执行失败的时候会返回0

  2. 使用expire命令,指定key的过期时间

setnx key value
expire key second
复制代码
Redis实现分布式锁

问题:

因为操作不是原子性的,如果在进行setnx的时候,刚好服务器宕机,没有来得及进行expire,那么该key将一直无法释放。

方案2

直接使用 redis 的原子命令:

set key value [EX seconds] [PX milliseconds] [NX|XX]
复制代码
  • EX: key在多少秒之后过期
  • PX:key在多少毫秒之后过期
  • NX: 当key不存在的时候,才创建key,效果等同于setnx
  • XX:当key存在的时候,覆盖key
Redis实现分布式锁

问题:

当同一时刻有大量的key过期的时候,删除key是需要时间的,可能导致redis出现暂时的卡顿现象,要如何解决?

答:在设置key过期时间的时候加上一个随机值


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

React 进阶之路

React 进阶之路

徐超 / 清华大学出版社 / 2018-4 / 69.00元

《React进阶之路》详细介绍了React技术栈涉及的主要技术。本书分为基础篇、进阶篇和实战篇三部分。基础篇主要介绍React的基本用法,包括React 16的新特性;进阶篇深入讲解组件state、虚拟DOM、高阶组件等React中的重要概念,同时对初学者容易困惑的知识点做了介绍;实战篇介绍React Router、Redux和MobX 3个React技术栈的重要成员,并通过实战项目讲解这些技术如......一起来看看 《React 进阶之路》 这本书的介绍吧!

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

html转js在线工具
html转js在线工具

html转js在线工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具