您的位置:首页技术文章
文章详情页

单实例mysql,表主键自增,在分布式大量插入的情况下主键会出现冲突吗?

【字号: 日期:2022-06-14 08:17:50浏览:56作者:猪猪

问题描述

单实例mysql,表主键自增,在分布式大量插入的情况下主键会出现冲突吗?(innodb/myisam)?

问题解答

回答1:

先说结论: 不会 。

第一种情况:mysql分布式一般是多台数据库通过日志来进行业务无关的同步,所以不会重复。

第二种情况:像淘宝这种特大型分布式则是分区写入。也就是淘宝他们不同区的业务依托的数据库是不一样的。其实就是若干个第一种情况的集合。自然也不会。

回答2:

冲突是不会的,但是要注意大并发量插入时会出现自增id争抢导致锁的情况,因为自增的原子操作还是先获取当前id值再插入,这中间必然会有锁,只不过效率高不易出现而已,所以业务上有大并发插入最好还是使用多实例分片方案

回答3:

我觉得应该不会冲突,但是这种高并发的时候,一个 MySQL 是搞不定的,你更要关心的是多个 MySQL 之间产生的 id 怎么不重复,有很多分布式环境下生成唯一 id 的办法。