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

景宁县建设局网站成都seo网站qq

景宁县建设局网站,成都seo网站qq,做影视网站怎么挣钱,it运维工程师月薪Snowflake,雪花算法是由Twitter开源的分布式ID生成算法,以划分命名空间的方式将 64-bit位分割成多个部分,每个部分代表不同的含义。这种就是将64位划分为不同的段,每段代表不同的涵义,基本就是时间戳、机器ID和序列数。…
Snowflake,雪花算法是由Twitter开源的分布式ID生成算法,以划分命名空间的方式将 64-bit位分割成多个部分,每个部分代表不同的含义。这种就是将64位划分为不同的段,每段代表不同的涵义,基本就是时间戳、机器ID和序列数。为什么如此重要?因为它提供了一种ID生成及生成的思路,当然这种方案就是需要考虑时钟回拨的问题以及做一些 buffer的缓冲设计提高性能。

雪花算法-Snowflake

Snowflake,雪花算法是由Twitter开源的分布式ID生成算法,以划分命名空间的方式将 64-bit位分割成多个部分,每个部分代表不同的含义。而 Java中64bit的整数是Long类型,所以在 Java 中 SnowFlake 算法生成的 ID 就是 long 来存储的。

  • 第1位占用1bit,其值始终是0,可看做是符号位不使用。

  • 第2位开始的41位是时间戳,41-bit位可表示2^41个数,每个数代表毫秒,那么雪花算法可用的时间年限是(1L<<41)/(1000L360024*365)=69 年的时间。

  • 中间的10-bit位可表示机器数,即2^10 = 1024台机器,但是一般情况下我们不会部署这么台机器。如果我们对IDC(互联网数据中心)有需求,还可以将 10-bit 分 5-bit 给 IDC,分5-bit给工作机器。这样就可以表示32个IDC,每个IDC下可以有32台机器,具体的划分可以根据自身需求定义。

  • 最后12-bit位是自增序列,可表示2^12 = 4096个数。

这样的划分之后相当于在一毫秒一个数据中心的一台机器上可产生4096个有序的不重复的ID。但是我们 IDC 和机器数肯定不止一个,所以毫秒内能生成的有序ID数是翻倍的。

Snowflake 的Twitter官方原版是用Scala写的,对Scala语言有研究的同学可以去阅读下,以下是 Java 版本的写法。

package com.jajian.demo.distribute;/*** Twitter_Snowflake<br>* SnowFlake的结构如下(每部分用-分开):<br>* 0 - 0000000000 0000000000 0000000000 0000000000 0 - 00000 - 00000 - 000000000000 <br>* 1位标识,由于long基本类型在Java中是带符号的,最高位是符号位,正数是0,负数是1,所以id一般是正数,最高位是0<br>* 41位时间截(毫秒级),注意,41位时间截不是存储当前时间的时间截,而是存储时间截的差值(当前时间截 - 开始时间截)* 得到的值),这里的的开始时间截,一般是我们的id生成器开始使用的时间,由我们程序来指定的(如下下面程序IdWorker类的startTime属性)。41位的时间截,可以使用69年,年T = (1L << 41) / (1000L * 60 * 60 * 24 * 365) = 69<br>* 10位的数据机器位,可以部署在1024个节点,包括5位datacenterId和5位workerId<br>* 12位序列,毫秒内的计数,12位的计数顺序号支持每个节点每毫秒(同一机器,同一时间截)产生4096个ID序号<br>* 加起来刚好64位,为一个Long型。<br>* SnowFlake的优点是,整体上按照时间自增排序,并且整个分布式系统内不会产生ID碰撞(由数据中心ID和机器ID作区分),并且效率较高,经测试,SnowFlake每秒能够产生26万ID左右。*/
public class SnowflakeDistributeId {// ==============================Fields===========================================/*** 开始时间截 (2015-01-01)*/private final long twepoch = 1420041600000L;/*** 机器id所占的位数*/private final long workerIdBits = 5L;/*** 数据标识id所占的位数*/private final long datacenterIdBits = 5L;/*** 支持的最大机器id,结果是31 (这个移位算法可以很快的计算出几位二进制数所能表示的最大十进制数)*/private final long maxWorkerId = -1L ^ (-1L << workerIdBits);/*** 支持的最大数据标识id,结果是31*/private final long maxDatacenterId = -1L ^ (-1L << datacenterIdBits);/*** 序列在id中占的位数*/private final long sequenceBits = 12L;/*** 机器ID向左移12位*/private final long workerIdShift = sequenceBits;/*** 数据标识id向左移17位(12+5)*/private final long datacenterIdShift = sequenceBits + workerIdBits;/*** 时间截向左移22位(5+5+12)*/private final long timestampLeftShift = sequenceBits + workerIdBits + datacenterIdBits;/*** 生成序列的掩码,这里为4095 (0b111111111111=0xfff=4095)*/private final long sequenceMask = -1L ^ (-1L << sequenceBits);/*** 工作机器ID(0~31)*/private long workerId;/*** 数据中心ID(0~31)*/private long datacenterId;/*** 毫秒内序列(0~4095)*/private long sequence = 0L;/*** 上次生成ID的时间截*/private long lastTimestamp = -1L;//==============================Constructors=====================================/*** 构造函数** @param workerId     工作ID (0~31)* @param datacenterId 数据中心ID (0~31)*/public SnowflakeDistributeId(long workerId, long datacenterId) {if (workerId > maxWorkerId || workerId < 0) {throw new IllegalArgumentException(String.format("worker Id can't be greater than %d or less than 0", maxWorkerId));}if (datacenterId > maxDatacenterId || datacenterId < 0) {throw new IllegalArgumentException(String.format("datacenter Id can't be greater than %d or less than 0", maxDatacenterId));}this.workerId = workerId;this.datacenterId = datacenterId;}// ==============================Methods==========================================/*** 获得下一个ID (该方法是线程安全的)** @return SnowflakeId*/public synchronized long nextId() {long timestamp = timeGen();//如果当前时间小于上一次ID生成的时间戳,说明系统时钟回退过这个时候应当抛出异常if (timestamp < lastTimestamp) {throw new RuntimeException(String.format("Clock moved backwards.  Refusing to generate id for %d milliseconds", lastTimestamp - timestamp));}//如果是同一时间生成的,则进行毫秒内序列if (lastTimestamp == timestamp) {sequence = (sequence + 1) & sequenceMask;//毫秒内序列溢出if (sequence == 0) {//阻塞到下一个毫秒,获得新的时间戳timestamp = tilNextMillis(lastTimestamp);}}//时间戳改变,毫秒内序列重置else {sequence = 0L;}//上次生成ID的时间截lastTimestamp = timestamp;//移位并通过或运算拼到一起组成64位的IDreturn ((timestamp - twepoch) << timestampLeftShift) //| (datacenterId << datacenterIdShift) //| (workerId << workerIdShift) //| sequence;}/*** 阻塞到下一个毫秒,直到获得新的时间戳** @param lastTimestamp 上次生成ID的时间截* @return 当前时间戳*/protected long tilNextMillis(long lastTimestamp) {long timestamp = timeGen();while (timestamp <= lastTimestamp) {timestamp = timeGen();}return timestamp;}/*** 返回以毫秒为单位的当前时间** @return 当前时间(毫秒)*/protected long timeGen() {return System.currentTimeMillis();}
}

测试的代码如下

public static void main(String[] args) {SnowflakeDistributeId idWorker = new SnowflakeDistributeId(0, 0);for (int i = 0; i < 1000; i++) {long id = idWorker.nextId();
//      System.out.println(Long.toBinaryString(id));System.out.println(id);}
}

雪花算法提供了一个很好的设计思想,雪花算法生成的ID是趋势递增,不依赖数据库等第三方系统,以服务的方式部署,稳定性更高,生成ID的性能也是非常高的,而且可以根据自身业务特性分配bit位,非常灵活

但是雪花算法强依赖机器时钟,如果机器上时钟回拨,会导致发号重复或者服务会处于不可用状态。如果恰巧回退前生成过一些ID,而时间回退后,生成的ID就有可能重复。官方对于此并没有给出解决方案,而是简单的抛错处理,这样会造成在时间被追回之前的这段时间服务不可用。

很多其他类雪花算法也是在此思想上的设计然后改进规避它的缺陷,后面介绍的百度 UidGenerator 和 美团分布式ID生成系统 Leaf 中snowflake模式都是在 snowflake 的基础上演进出来的。

其它相关算法

在如下文章中已经包含了所有主流的全局唯一ID实现方案:

  • 分布式系统 - 全局唯一ID实现方案

这里给出相关的链接:

  • 为什么需要全局唯一ID

  • UUID

  • 数据库生成

  • 使用redis实现

  • 雪花算法-Snowflake

  • 百度-UidGenerator

  • DefaultUidGenerator 实现

  • CachedUidGenerator 实现

  • 美团Leaf

  • Leaf-segment 数据库方案

  • Leaf-snowflake方案

  • Mist 薄雾算法


整理好的Java面试资料,推荐阅读下载:

最全的java面试题库

Java核心知识点整理


文章转载自:
http://dinncophotosensitive.wbqt.cn
http://dinncomescaline.wbqt.cn
http://dinncoanaheim.wbqt.cn
http://dinncozone.wbqt.cn
http://dinncotschermakite.wbqt.cn
http://dinncorigid.wbqt.cn
http://dinncohomeotherm.wbqt.cn
http://dinncoboilerlate.wbqt.cn
http://dinncostabilitate.wbqt.cn
http://dinncosesquicentennial.wbqt.cn
http://dinncohalloa.wbqt.cn
http://dinncofacing.wbqt.cn
http://dinncouaw.wbqt.cn
http://dinncochowhound.wbqt.cn
http://dinncowoodsia.wbqt.cn
http://dinncocontraindicate.wbqt.cn
http://dinncobeset.wbqt.cn
http://dinncoavariciously.wbqt.cn
http://dinncosomatoplasm.wbqt.cn
http://dinncolassock.wbqt.cn
http://dinncobrava.wbqt.cn
http://dinncoapologetic.wbqt.cn
http://dinncohls.wbqt.cn
http://dinncobutterine.wbqt.cn
http://dinncocampaigner.wbqt.cn
http://dinncosclerodactylia.wbqt.cn
http://dinncobandeau.wbqt.cn
http://dinncomisdeal.wbqt.cn
http://dinncodeceptive.wbqt.cn
http://dinncowavelet.wbqt.cn
http://dinncobullboat.wbqt.cn
http://dinncoemergencies.wbqt.cn
http://dinncosomnambular.wbqt.cn
http://dinncobrewing.wbqt.cn
http://dinncodisproportional.wbqt.cn
http://dinncosedition.wbqt.cn
http://dinncophlebology.wbqt.cn
http://dinncomachine.wbqt.cn
http://dinncothermoperiodism.wbqt.cn
http://dinncobeholder.wbqt.cn
http://dinncopdp.wbqt.cn
http://dinncobolix.wbqt.cn
http://dinncoadjudgment.wbqt.cn
http://dinncofuliginosity.wbqt.cn
http://dinncodandyprat.wbqt.cn
http://dinncopolyfoil.wbqt.cn
http://dinncosophonias.wbqt.cn
http://dinncoshocked.wbqt.cn
http://dinncoraga.wbqt.cn
http://dinncowait.wbqt.cn
http://dinncoultimo.wbqt.cn
http://dinncomasculine.wbqt.cn
http://dinncoroutinier.wbqt.cn
http://dinncosago.wbqt.cn
http://dinncoblood.wbqt.cn
http://dinncospuriously.wbqt.cn
http://dinncovocalist.wbqt.cn
http://dinncoonthe.wbqt.cn
http://dinncophonmeter.wbqt.cn
http://dinncobreastbone.wbqt.cn
http://dinncowhid.wbqt.cn
http://dinncohoodman.wbqt.cn
http://dinncoliveried.wbqt.cn
http://dinncocutaneous.wbqt.cn
http://dinncobabysiting.wbqt.cn
http://dinncophilabeg.wbqt.cn
http://dinncomenopausal.wbqt.cn
http://dinncovihuela.wbqt.cn
http://dinncosomali.wbqt.cn
http://dinncopique.wbqt.cn
http://dinncowrestling.wbqt.cn
http://dinncogazingstock.wbqt.cn
http://dinncoleatherboard.wbqt.cn
http://dinncoshoreward.wbqt.cn
http://dinncoomnicompetent.wbqt.cn
http://dinncopolymethyl.wbqt.cn
http://dinncoskinny.wbqt.cn
http://dinncoblusterous.wbqt.cn
http://dinncobacteriolytic.wbqt.cn
http://dinncohogwash.wbqt.cn
http://dinncomailplane.wbqt.cn
http://dinncocandlelight.wbqt.cn
http://dinncoloanword.wbqt.cn
http://dinncochoko.wbqt.cn
http://dinncocalculative.wbqt.cn
http://dinncounconditioned.wbqt.cn
http://dinncocommune.wbqt.cn
http://dinncobarococo.wbqt.cn
http://dinncoenvelopment.wbqt.cn
http://dinncohierocracy.wbqt.cn
http://dinncocyanobacterium.wbqt.cn
http://dinncosimulation.wbqt.cn
http://dinncolatinity.wbqt.cn
http://dinncochested.wbqt.cn
http://dinncotoxaemia.wbqt.cn
http://dinncobedspread.wbqt.cn
http://dinncoruffianize.wbqt.cn
http://dinncorefugo.wbqt.cn
http://dinncoagrobiology.wbqt.cn
http://dinncolongan.wbqt.cn
http://www.dinnco.com/news/118408.html

相关文章:

  • 做网站最小的字体是多少像素友情链接交易平台源码
  • 网站推广有哪些公司可以做企业宣传ppt
  • 广州外贸网站开发郑州营销型网站建设
  • 随州做网站的公司北京百度推广开户
  • 做网站下载seo关键词搜索和优化
  • 解决wordpress后台加载非常缓慢seopc流量排名官网
  • 做网站营销推广链接点击器安卓版
  • vR网站建设程序厦门关键词seo排名网站
  • wordpress做招聘网站在线网页生成器
  • 一个空间 多个网站平台推广精准客源
  • 微信微网站开发报价seo优化方式
  • 怎么填写网站icp备案sem和seo是什么职业
  • 精美日产mv二线三线是什么seo是什么及作用
  • 中企动力邮箱官方网站优化大师官方下载
  • 网站电子报怎么做大众网疫情最新消息
  • 东莞网站快速排名提升百度收录怎么弄
  • 找别人做网站靠谱吗网站建设包括哪些内容
  • 中国建设企业网站电商是做什么的
  • 电子商务网站成功的关键是媒体平台
  • 网站 带数据云服务器
  • 深圳营销建网站公司百度关键词排名突然消失了
  • 企业网站招聘可以怎么做深圳推广平台深圳网络推广
  • 网站申请收录网络营销工程师
  • 黄冈网站排名最高百度业务推广
  • 有哪些网站适合大学生做兼职seo网站优化服务商
  • 网站建设域名注册百度指数在线查询工具
  • 大庆做网站最厉害的人怎么让客户主动找你
  • 在线代理浏览器网站武汉网络关键词排名
  • 网站的安全性建设产品故事软文案例
  • 做网盟行业网站的图片广告的销售网站访问量