用MySQL实现发号器
浏览:3175次 出处信息
问题:用MySQL实现发号器功能,确保每次取到的ID号都是唯一的
实现:下面是一个大致的思路,抛个砖,欢迎回帖。
根据号段大小,决定是否分成多个表,每个表事先填充各个不同的号段。
每个应用端取号时,设置事务隔离级别为:REPEATABLE READ,并且采用下面的方式读取数据
以下是代码片段: SELECT `ID` FROM `ID_RANGE_XX` ORDER BY ID LIMIT 1 FOR UPDATE |
在上述情境中,只要选择某个ID号,那么其他终端也在读取该号时,会产生锁等待,而不会发生ID号被重用的情况。
考虑到并发的问题,建议增加分表数量,每次循环或随机从分表中读取数据,降低对单个表的并发请求。
建议继续学习:
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:通过PostgreSQL的源代码安装数据库
后一篇:(总结)mysql中对已存在的表做增/删/改列的相关操作 >>
文章信息
- 作者:yejr 来源: MySQL 中文网 -
- 标签: 发号器 唯一号
- 发布时间:2010-07-21 09:45:07
建议继续学习
近3天十大热文
- [382] 如何拿下简短的域名
- [381] WEB系统需要关注的一些点
- [11] Python中的闭包
- [11] Mysql监控指南
- [11] 大并发下的高性能编程 – 改进的(用户态)自
- [11] 关于身份证号的那些事
- [10] Zookeeper工作原理
- [10] 分布式系统的事务处理
- [10] 一致性哈希算法及其在分布式系统中的应用
- [9] 什么是DNS劫持和DNS污染?