当前位置: 首页 > news >正文

分布式ID系统设计(2)

接上文

https://editor.csdn.net/md/?articleId=133988963

类snowFlake 方案

  • 应用举例 mongoDB ObjectID 就是一个典型的实现。

数据库生成

以MySQL举例 利用给字段设置AUTO-INCREMENT来保证ID自增,每次业务使用SQL拿到MySQL的ID
这种方案的优缺点:

  • 优点
    1 简单。利用数据库实现 成本小,有专业的DBA维护
    2 ID单调递增。用来实现一些对于ID有特殊要求的业务
  • 缺点
    1 强依赖DB,当整个DB异常整个系统不可用,属于致命问题
    2 ID发号性能瓶颈在于单台DB的读写性能

对于MySQL的性能问题,可以考虑多部署几台机器。然后设置不同的初始值,步数长和机器数相等。
Flickr论文
但是这玩意看起来能满足。但是存在的问题:

  • 系统基本属于无法水平拓展。因为你定义好了步长 都写死了。如果后续发现性能不够要加机器 怎么处理?
  • ID没有单调递增。只能趋势递增。当然对于一般业务也没什么。可以忍受
  • 数据库压力大。毕竟都读写一次DB
  • 当然也可以用redis 但是还是一样的问题
  • <
http://www.lryc.cn/news/217259.html

相关文章:

  • http和https的区别,以及https涉及到的加密过程
  • 使用php打印时间精确到毫秒及毫秒转成11位时间戳
  • uni-app离线打包在android studio创建的.jks证书,签名文件获取MD5问题
  • 333333333333
  • Python:字符串格式化
  • 虹科示波器 | 汽车免拆检修 | 2010款江铃陆风X8车发动机怠速抖动、加速无力
  • 左和右,激进与保守,都是相对概念,但是都会滑向同一种
  • js中的遍历
  • Python算法——快速排序
  • 操作系统备考学习 day12 (第五章)
  • Elasticsearch删除映射类型
  • 网络工程师进阶课:华为HCIP认证课程介绍
  • 单行自动横向滚动——css实现
  • 多线程基础
  • 贝锐向日葵亮相阿里云“云栖大会”:独创专利算法赋能全新云桌面
  • QT在线安装5.15之前的版本(下载速度飞快)
  • 零日漏洞预防
  • 企业内部外网向内网传输文件如何实现高效安全?
  • C++--二叉搜索树初阶
  • Type List(C++ 模板元编程)
  • 使用老北鼻CharGPT对话查询 Qt/C++ 使用gumbo-parse解析加载的html全过程
  • ​ iOS App Store上传项目报错 缺少隐私政策网址(URL)解决方法
  • 设计模式第一课-单例模式(懒汉模式和饿汉模式)
  • Yaml文件详解
  • 【题解 线段树】[蓝桥杯 2022 省 A] 选数异或
  • 宠物喂食器方案智能开发设计
  • chatgpt综述阅读理解
  • XCTF-RSA-2:baigeiRSA2、 cr4-poor-rsa
  • js 根据word文档模板导出内容
  • AIGC | 如何用“Flow”,轻松解决复杂业务问题