| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> 分布式锁的三种实现方式 -> 正文阅读 |
|
[大数据]分布式锁的三种实现方式 |
分布式锁实现方式主要有三种,数据库,Redis 和 ZooKeeper。 1、数据库实现分布式锁 使用select field from table_name? where idx = n for update 关键词 for update,如果 idx为主键或索引字段,这样就会使用行锁,相同记录进行操作会阻塞,等待锁释放后才能继续,可以设置超时时间,如 for update 2s,获取不到锁就报异常。这种方式不会影响对其他行的 write 操作,也不会影响对表数据的 read 操作,不建议并发量很大的情况下使用,用户体验不好。 2、Redis 实现分布式锁 setnx方法,指定 key 不存在时设置 value,如果已存在,直接报错,简单粗暴。因为加锁,超时,释放锁分别设置,不是原子操作,正常情况下设置超时时间,这样即使程序异常没有手动释放锁,也可以实现一定时间后自动释放锁。 3、ZooKeeper 实现分布式锁 使用zk原生API实现分布式锁比较麻烦,可以直接使用Curator,简单的API就可以实现。 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/24 10:52:18- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |