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

金色网站模板交互设计考研院校

金色网站模板,交互设计考研院校,微网站页面菜单栏,网站数据迁移教程分布式ID系统设计第三集 id-service-SnowFlake方案 第二集说了id-service-Segment-DB可以生成趋势递增的ID,但是ID号是可以计算的。不太适用于一些订单ID生成的场景。因为存在数据暴露的风险 比如我可以对比两天的订单ID号来大致计算出公司一天的订单量。这个有点危险。 所以…

分布式ID系统设计第三集

id-service-SnowFlake方案

第二集说了id-service-Segment-DB可以生成趋势递增的ID,但是ID号是可以计算的。不太适用于一些订单ID生成的场景。因为存在数据暴露的风险

比如我可以对比两天的订单ID号来大致计算出公司一天的订单量。这个有点危险。

所以我们需要id-serviceSnowFlake方案。
id-service-snowFlake完全沿用snowFlake方案的bit位设计。即"1+41+10+12"的方式组装id。对于workid的分配 基本上可以用手动配置。也可以借助Zk或者etcd CP实现的分布式协调者来配置。id-service-SnowFlake按照下面几个步骤启动:

1 启动id-servicesnowFlake。连接zk或者etcd。在id-service-snowflake父节点下检查自己是否已注册。
2 如果有就直接拿到自己的workId zk/etcd 生成的id 启动。
3 如果没有就在根下面生成一个节点id 当作自己的workId
4 start-service

弱依赖zk

如果想做到这一步就在本地osFile上。当zk出现问题的时候,而服务又要重启。这个时候这一步就能提高SLA.

解决时钟问题

因为这种方案依赖时间。如果机器的时钟发生了回拨。那么有可能生成重复的ID.那就需要解决这个问题。

1 首先服务注册到zk 检查自己是否写如果zk
2 如果写过 则用自己的系统时间与id-service-forever/{id}节点记录时间做比较 如果小于则认为机器时间发生了回拨,这个时候可以选择等待也可以选择失败退出。
3 如未写过 则直接注册进去。然后对比其他节点的系统时间判断自己系统时间是否正确。可以选择轮训对比 也可以选择相加/节点数对比
4 若时间正确就启动 写入zk
5 否则认为有回拨。
6 每隔一段时间上报自己的系统时间写入zk

由于强依赖时钟,对时钟要求很敏感。如果机器上有NTP时间服务同步的话。在他同步的时候会造成秒级的回拨。(不过一般的公司也不会有这种业务量 除了大厂)。解决方案就是在回拨的时候等待一段时间(1s 2s 这样)或者直接重试.再或者直接摘除节点 告警。

代码实现也很简单
/发生了回拨,此刻时间小于上次发号时间
if (timestamp < lastTimestamp) {

        long offset = lastTimestamp - timestamp;if (offset <= 5) {try {//时间偏差大小小于5ms,则等待两倍时间wait(offset << 1);//waittimestamp = timeGen();if (timestamp < lastTimestamp) {//还是小于,抛异常并上报throwClockBackwardsEx(timestamp);}    } catch (InterruptedException e) {  throw  e;}} else {//throwthrowClockBackwardsEx(timestamp);}}

从使用情况来看 基本没有出现过问题。

id-service 情况

作为一个基架服务。性能应该是最关心的 能在4C8G机器上跑出4w QPS.可用性也能保证9999.提供给6个BU 一天有个几百万的使用量。作为基架。高SLA和高性能是必须要保证的。

http://www.15wanjia.com/news/178687.html

相关文章:

  • 做会计要关注什么网站wordpress能制作视频网站吗
  • php网站框架西安网站建设sxyun
  • 做博客网站的php代码wordpress上传视频黑屏
  • 郑州网站建设361山东企业网站建设哪家好
  • html5导航网站源码新闻热点事件2020 最新
  • 能自己做生物实验的网站html 图片展示网站
  • 深圳建一个网站多少钱网站建设的常用软件有哪些
  • 网站建设需要学多久知乎做淘宝网站多少钱
  • 网站后台登陆不进去做讲课ppt的网站
  • 扬中网站建设包括哪些做yield网站多少钱
  • 有做阿里网站的吗张家港专业做网站
  • wordpress网站反应慢哪些网站教你做系统
  • 做网站的名字大全小程序怎么制作网站
  • 企业做网站属于广告宣传费吗湛江做网站建设
  • 网站制作2007深圳品牌网站制作多少钱
  • 企业网站特点遵义网吧什么时候恢复营业
  • 自己做的网站某个网页打开很慢保健品网站设计
  • 怎么在网上免费做公司网站企业网站建设实训心得
  • 网站关键词锚文本指向wordpress还能打开吗
  • 宁夏做网站的公司网站诊断与检测
  • 网站建设栏目设计支付网站服务费怎么做分录
  • 个人免费注册公司网站小程序开发工具代理平台
  • 世界工厂采购网站做网站备案须知
  • 中国传统色彩网站建设方案合肥做网站推广的公司
  • es网站开发wordpress图片使用图床
  • 网页源码怎么做网站高端网站制作哪家好
  • 北京响应式h5网站开发开发网站的基本原则
  • 公司网站招聘模板网页开发培训学校
  • 没有域名的网站需要备案吗兰州市住房保障和城乡建设局网站
  • 网站备案在哪里电商网站建设实训报告心得