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

福州网站建设案例seo关键词优化服务

福州网站建设案例,seo关键词优化服务,网站建设丿金手指下拉9,谁帮58同城做的网站吗欢迎来到啾啾的博客🐱。 记录学习点滴。分享工作思考和实用技巧,偶尔也分享一些杂谈💬。 有很多很多不足的地方,欢迎评论交流,感谢您的阅读和评论😄。 目录 1 分布式ID2 问题2.1 时钟回拨2.1.1 毫秒级时钟回…

欢迎来到啾啾的博客🐱。
记录学习点滴。分享工作思考和实用技巧,偶尔也分享一些杂谈💬。
有很多很多不足的地方,欢迎评论交流,感谢您的阅读和评论😄。

目录

  • 1 分布式ID
  • 2 问题
    • 2.1 时钟回拨
      • 2.1.1 毫秒级时钟回拨则进行等待
      • 2.1.2 引入时钟回拨位
      • 2.1.3 基于外部
      • 2.1.4 混合时间戳
    • 2.2 序列号耗尽
      • 2.2.1 等待时间戳
      • 2.2.2 调整结构,增加序列号位数
      • 2.2.3 多ID生成器

现在典型的八股都是凝练了问题,背后有着对问题的认知和解决思路。
一直想写一个八股系列,从问题到原理。从这篇开始吧。

面试题:分布式ID时钟回拨怎么处理?序列号耗尽了怎么办?

1 分布式ID

分布式ID均会有一些需求。
高性能:有序
可维护:包含时间
可用:唯一

结构经常是多段结构,以UUIDv7为例

[ 48位毫秒时间戳 ] [ 4位版本号'7' ] [ 76位随机数 ]

基于此,经常面临的问题如下。

2 问题

2.1 时钟回拨

2.1.1 毫秒级时钟回拨则进行等待

毫秒级时钟回拨,且对延迟不敏感场景。让ID生成器等待系统时钟追赶上上一次时间。

long generateId() {long currentTimestamp = getCurrentTimeMillis();while (currentTimestamp < lastTimestamp) {// 检测到时钟回拨,等待Thread.sleep(1);currentTimestamp = getCurrentTimeMillis();}// 继续生成IDif (currentTimestamp == lastTimestamp) {sequence = (sequence + 1) & 4095; // 序列号递增if (sequence == 0) {// 序列号用尽,等待下一毫秒currentTimestamp = waitNextMillis(currentTimestamp);}} else {sequence = 0; // 新毫秒,重置序列号}lastTimestamp = currentTimestamp;return (currentTimestamp << 22) | (machineId << 12) | sequence;
}

2.1.2 引入时钟回拨位

引入时钟回拨位。在ID结构中预留几位作为“时钟回拨位”(rollback bits),当检测到时钟回拨时,递增回拨位以区分ID,避免重复。

2.1.3 基于外部

即给予外部服务的时钟,避免依赖本地时钟,如使用Redis生成递增ID。

  • 在Redis中每天生成一个Key(如date:20250615),通过INCR操作生成递增序列号。
  • ID格式:日期 + 机器ID + Redis递增序列号。

2.1.4 混合时间戳

结合物理时钟和逻辑时钟,生成混合时间戳,确保即使发生回拨,ID仍保持唯一性和递增性。

使用Google的TrueTime或类似机制,维护一个时间区间([min, max]),确保时间戳在安全范围内。
检测到回拨时,使用逻辑计数器递增,确保ID唯一。

2.2 序列号耗尽

在分布式ID生成中(如Snowflake算法),序列号耗尽是指在同一时间戳(通常是毫秒级)内,序列号部分达到了最大值(例如,12位序列号的最大值是4095),无法继续生成新的唯一ID。这是一个常见问题,尤其在高并发场景下,同一毫秒内可能需要生成大量ID。

2.2.1 等待时间戳

毫秒级的方案等待下一毫秒,纳秒级的方案等待下一纳秒。

long generateId() {long currentTimestamp = getCurrentTimeMillis();if (currentTimestamp < lastTimestamp) {// 处理时钟回拨(参考上一回答)handleClockRollback();}if (currentTimestamp == lastTimestamp) {sequence = (sequence + 1) & 4095; // 递增序列号if (sequence == 0) {// 序列号耗尽,等待下一毫秒currentTimestamp = waitNextMillis(currentTimestamp);}} else {sequence = 0; // 新时间戳,重置序列号}lastTimestamp = currentTimestamp;return (currentTimestamp << 22) | (machineId << 12) | sequence;
}long waitNextMillis(long lastTimestamp) {long current = getCurrentTimeMillis();while (current <= lastTimestamp) {current = getCurrentTimeMillis();}return current;
}

2.2.2 调整结构,增加序列号位数

通过调整ID结构,增加序列号的位数(例如从12位增加到14位),从而支持每毫秒生成更多ID。

2.2.3 多ID生成器

通过引入多个ID生成器实例或分片,分散ID生成压力,降低单个实例的序列号耗尽概率。
比如雪花ID的Snowflake,可以为每个节点分配多个机器ID(例如,节点A使用机器ID 1-4,节点B使用5-8)。
当序列号耗尽时,切换到另一个实例生成ID。

http://www.ho-use.cn/article/2874.html

相关文章:

  • 动态网站的主要特点在线分析网站
  • 东城东莞网站建设上海b2b网络推广外包
  • 邯郸网站建设推广搜狗seo软件
  • 怎么做网站才能吸引人网络排名优化软件
  • 邦策网站建设平台seo搜索引擎优化推广
  • 武威住房和城乡建设厅网站今晚日本比分预测
  • 如何做自动采集视频网站源码网站推广线上推广
  • 网页设计教程教学目的北京seo优化哪家公司好
  • 网站后台发布新闻seo数据统计分析工具有哪些
  • 做网站不备案用香港空间可以吗太原网站排名推广
  • shopex网站备份网店推广实训报告
  • 合肥瑶海区教育局官网优化大师免费安装下载
  • 设计大型网站建设网站推广优化的原因
  • 高清做视频在线观看网站设计公司企业网站
  • 个人如何做微商城网站设计旺道seo优化软件怎么用
  • 物流网站的分类深圳seo排名优化
  • 中国工商注册网企业年报系统淘宝seo优化是什么
  • 用php做动态网站吗推广技术
  • 工业设计公司经营范围有哪些网站seo文章该怎么写
  • h5制作小程序有哪些江苏seo推广
  • metro风格网站开发怎么样把广告做在百度上
  • 深圳附近做个商城网站哪家公司便宜点工具seo
  • 创新的大良网站建设营销网络推广方式有哪些
  • 做购物网站seo课程培训要多少钱
  • 云南微网站制作谷歌搜索引擎
  • 怎么做刷业网站网站开发合同
  • 深圳做网站网络公司营销图片大全
  • 上海市工程建设质量管理协会网站可靠的网站优化
  • 餐饮食材配送网站开发企划书seo挂机赚钱
  • 杭州移动网站建设服务器域名查询