单实例mysql,表主键自增,在分布式大量插入的情况下主键会出现冲突吗?
阿神
阿神 2017-04-17 16:44:21
[MySQL讨论组]

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

阿神
阿神

闭关修行中......

全部回复(3)
PHPz

先说结论: 不会 。

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

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

PHP中文网

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

迷茫

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号