• 授权协议:MIT
  • 开发厂商:-
  • 软件语言:Google Go
  • 更新日期:2018-06-12
SEQSVR

SEQSVR Go + MySQL 实现的 ID 生成服务

SEQSVR Go + MySQL 实现的 ID 生成服务 项目简介

SEQSVRGo + MySQL 实现的 ID 生成服务特性分布式:可任意横向扩展高性能:分配 ID 只访问内存(到达上限会请求数据库一次)易用性:对外提供 HTTP 服务唯一性:MySQL 自增 ID,永不重复高可靠:MySQL 持久化依赖项本项目使用下列优秀的项目作为必要组件。gopkg.in/yaml.v2github.com/go-sql-driver/mysqlgithub.com/satori/go.uuid安装注意:需要在启动之前创建数据库并修改配置文件中数据库的配置。go get 方式:需保证 $GOPATH/bin 在系统 PATH 中。go get github.com/qichengzx/seqsvr
seqsvr单独编译:git clone [email protected]:qichengzx/seqsvr.git
cd seqsvr
go build .
./seqsvrDocker 方式:Dockerfile 使用了 Docker 多阶段构建功能,需保证 Docker 版本在 17.05 及以上。详见:Use multi-stage buildsgit clone [email protected]:qichengzx/seqsvr.git
cd seqsvr
docker build seqsvr:latest .
docker run -p 8000:8000 seqsvr:latest初始化数据库数据库名称可以自定义,修改 config.yml 即可。然后导入以下 SQL 生成数据表。CREATE TABLE `generator_table` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `uuid` char(36) NOT NULL COMMENT '机器识别码',
  PRIMARY KEY (`id`),
  UNIQUE KEY `id_UNIQUE` (`id`),
  UNIQUE KEY `stub_UNIQUE` (`uuid`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;修改配置配置文件使用 YAML 格式。#app
port: ':8000'

#service
step: 100

#db
mysql:
  user: 'root'
  password: ''
  host: 'tcp(localhost:3306)'
  database: 'sequence'可修改端口号及 MySQL 的配置。使用curl http://localhost:8000/new{"code":0,"msg":"ok","data":{"id":101}}原理本项目设计原理来自 携程技术中心 的干货 | 分布式架构系统生成全局唯一序列号的一个思路。服务初始化后第一次请求会在 MySQL 数据库中插入一条数据,以生成初始 ID。后续的请求,都会在内存中进行自增返回,并且保证返回的 ID 不会超过设置的上限,到达上限后会再次从 MySQL 中更新数据,返回新的初始 ID 。核心SQLREPLACE INTO `generator_table` (uuid) VALUES ("54f5a3e2-e04c-4664-81db-d7f6a1259d01");

SEQSVR Go + MySQL 实现的 ID 生成服务 相关推荐

SEQSVR Go + MySQL 实现的 ID 生成服务 评论内容