基于 MySQL 的 ID 生成器 idgo

码农软件 · 软件分类 · 其他开发相关 · 2019-10-19 09:44:11

软件介绍

idgo是一个利用MySQL批量生成ID的ID生成器, 主要有以下特点:

  • 每次通过事务批量取ID,性能较高,且不会对MySQL造成压力.

  • 当ID生成器服务崩溃后,可以继续生成有效ID,避免了ID回绕的风险.

业界已经有利于MySQL生成ID的方案,都是通过:

REPLACE INTO Tickets64 (stub) VALUES ('a');
SELECT LAST_INSERT_ID();

这种方式生成ID的弊端就是每生成一个ID都需要查询一下MySQL,当ID生成过快时会对MySQL造成很大的压力. 这正是我写这个lib库的原因.

idgo服务正确性和高可用保障措施

1. 压力测试结果

压测环境

类别名称
OSCentOS release 6.4
CPUCommon KVM CPU @ 2.13GHz
RAM2GB
DISK50GB
Mysql5.1.73

本地mac连接远程该MySQL实例压测ID生成服务。 每秒中可以生成20多万个ID。性能方面完全不会有瓶颈。

2.ID生成正确性验证

模拟4个进程(cmd/example.go)以每秒生成100个ID的频率并发向MySQL IDGEN服务申请ID,并将生成的ID写入MySQL。 测试16小时后,生成330万个ID,未发现有重复ID。

3.ID生成服务宕机后的恢复方案

当idgo服务意外宕机后,可以切从库,然后将idgo对应的key加上适当的偏移量。

4. 使用方法

参考cmd/example.go文件使用, 用起来很简单. :)

编译并运行example.go

. ./dev.sh
make
./bin/cmd

本文地址:https://codercto.com/soft/d/17083.html

程序员的修炼

程序员的修炼

Jeff Atwood / 陆其明、杨溢 / 人民邮电出版社 / 2014-4 / 45.00元

《程序员的修炼——从优秀到卓越》是《高效能程序员的修炼》的姊妹篇,包含了Coding Horror博客中的精华文章。全书分为8章,涵盖了时间管理、编程方法、Web设计、测试、用户需求、互联网、游戏编程以及技术阅读等方面的话题。作者选取的话题,无一不是程序员职业生涯中的痛点。很多文章在博客和网络上的点击率和回帖率居高不下。 Jeff Atwood于2004年创办Coding Horror博客(......一起来看看 《程序员的修炼》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

SHA 加密
SHA 加密

SHA 加密工具