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

哪个网站做外链视频好网页设计师工作室

哪个网站做外链视频好,网页设计师工作室,短视频推广平台,外贸流程全步骤 外贸篇欢迎来到啾啾的博客#x1f431;。 记录学习点滴。分享工作思考和实用技巧#xff0c;偶尔也分享一些杂谈#x1f4ac;。 有很多很多不足的地方#xff0c;欢迎评论交流#xff0c;感谢您的阅读和评论#x1f604;。 目录 1 分布式ID2 问题2.1 时钟回拨2.1.1 毫秒级时钟回… 欢迎来到啾啾的博客。 记录学习点滴。分享工作思考和实用技巧偶尔也分享一些杂谈。 有很多很多不足的地方欢迎评论交流感谢您的阅读和评论。 目录 1 分布式ID2 问题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.hkea.cn/news/14364269/

相关文章:

  • 模板网站seo模块建筑
  • 能在家做的兼职的网站本人有五金件外发加工
  • 江苏建站系统青岛网站备案
  • 网站开发中设置会员等级网站开发项目答辩主持词
  • 东莞市公司网站建设服务机构官网建设费用入什么科目
  • 天猫网站的建设建e网客厅效果图
  • 广州建设网站的公司简介wordpress登陆图标修改
  • 网站用花生壳nas做存储怎样用自己电脑做网站
  • 网站推广只能使用在线手段进行。网站建设0doit
  • 寻花问柳一家专注做男人喜爱的网站企业网站建设怎么做
  • 图片1600px做网站wordpress 函数手册
  • 百度网站入口网络营销工具分析
  • 大丰区城乡和住房建设局网站烟台seo
  • 昆明高端网站设计企业注册名字查询
  • 网站建设的基础是什么意思网站登录注册页面模板下载
  • lanyun网站开发wordpress老版编辑
  • 青岛网站关键词推广一个电商网站开发需要多久
  • 做网站卖装备wordpress wechat pay
  • 整站排名服务网站建设贴吧
  • 建设银行网站怎么登陆密码错误百度小程序给网站做链接
  • 柳州商城网站开发阿里云服务器是干什么用的
  • 从0开始做网站龙口网站建设哪家好
  • 公司网站设计案例成都网推公司
  • 做网站app要多钱网站建设和网站设计公司在哪里
  • 广州南沙区建设和交通局网站注册深圳公司代理
  • 网站seo检测工具wordpress评论回复邮件通知
  • 怎样做自己的摄影网站百度联盟怎么做自己的网站
  • 网站建设在线建站那些提卡网站是怎么做的
  • 网站内部优化有哪些内容网站建设与管理多选题
  • 网络上做假网站做物流网站制作建设模板