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

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

阅读 8.1k
4 个回答

先说结论: 不会 。

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

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

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

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题