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

响应式网站模板是什么百度推广是干什么的

响应式网站模板是什么,百度推广是干什么的,南京网络设计,做网站怎样让字体滚动概念 所谓数据发生器,最典型的就是 Oracle 的 sequence,用户通过 sequence.nextval 可以取得一组连续的值。 但是,一般实现里,sequence.nextval 是依赖于单线程生成,无法做到并发。 一个优秀的分布式顺序数据发生器…

概念

所谓数据发生器,最典型的就是 Oracle 的 sequence,用户通过 sequence.nextval 可以取得一组连续的值。

但是,一般实现里,sequence.nextval 是依赖于单线程生成,无法做到并发。

一个优秀的分布式顺序数据发生器,需要满足三个条件:

  1. 分布式生成
  2. 有序
  3. 稠密

算法

本文探讨一种实现方法,它由“分布式行生成器” 和“分布式序列生成函数” 两部分组成。同时,为了支持分布式生成,需要引入 worker id 的概念,取值从 0 到 N - 1,N为并发度。提供给用户的接口为:

select nextval() from table(generator(100));

其中,table(generator(100)) 为分布式行生成器,nextval() 为分布式序列生成函数。
为了实现分布式的行生成,则需要:

  • 规划好 N 个线程里,每个 table(generator(100)) 实例能生成多少个数字。
  • 规划好 N 个线程里,nextval() 实例能生成哪些数字

先看最简单的场景,N=10, Rows=100,我们有两种生成策略。

策略1:

Worker IdRowsValues
0100,1,2,3…,9
11010,11,12,…,19
91090,91,92,…,99

策略2:

Worker IdRowsValues
0100,10,20,30…,90
1101,11,21,…,91
9109,19,29,…,99

稍微复杂一点的场景:N=10, Rows=103,就会给我带来一些疑问:

  • table(generator(100)) 实例的行数生成算法是什么?
  • nextval() 实例的数字生成公式是什么?

下面给出一个算法:

rows = worker_id * (Rows / N) + (worker_id < Rows % N ? 1 : 0)
initialize nextval.next = worker_id;
nextval.next = nextval.next + N;

基于这个算法,的到的数据表格为:

Worker IdRowsValues
0110,10,20,30…,90,100
1111,11,21,…,91,101
2112,12,22,…,92,102
3103,13,23,…,93
4104,41,21,…,91
9109,19,29,…,99

再给一个算法,剩余的数字由最后一个线程生成:

rows = worker_id * (Rows / N) + (worker_id == N -1 ? Rows % N : 0)
initialize nextval.next = worker_id * N;
nextval.next = nextval.next + 1;
Worker IdRowsValues
0100,1,2,3…,9
11010,11,12,…,19
91390,91,92,…,99,100,101,102

考虑到 N 一般不大,两种算法看上去都还行。

但考虑到更少 corner case 的话,第一种算法的倾斜更少,更为推荐。第二种算法,一个典型的 corner case 就是:N = 10, total_rows = 9 的时候,所有行都是由最后一个线程(worker id = 9)生成。如果这是一个比较底层的驱动表,可能会导致后继非常严重的 skew。

结论

分布式顺序数据发生器算法如下

rows = worker_id * (Rows / N) + (worker_id < Rows % N ? 1 : 0)
initialize nextval.next = worker_id;
nextval.next = nextval.next + N;

值得注意的是,nextval() 函数此时是一个有状态函数,它需要记住上一次的 nextval 值。

基于这个算法,每个线程要生成多少数字,生成什么数字,都是预先约定的,无需线程之间的通信,是一种高效的无锁并行算法。

http://www.dtcms.com/wzjs/191270.html

相关文章:

  • 利用access数据库做网站百度爱采购官网首页
  • 做网站多少流量可以做广告软文广告营销
  • behance设计网站怎么进去搜一搜排名点击软件
  • 重庆网站建设子沃科技武汉seo服务外包
  • 网站设计建设广州市新闻最新消息
  • Wordpress显示toolbar二十条优化措施全文
  • 网站建设与网站优化销售郑州网络营销学校
  • 主机屋网站搭建设置北京seo优化多少钱
  • 企业网站建设第一步google play官网入口
  • 运城建设厅官方网站站内关键词自然排名优化
  • 石家庄企业网站建设价格关键词优化收费标准
  • iis部署网站 http 500 - 内部服务器错误行业门户网站推广
  • 美女做爰免费观看视频网站怎么做起泡胶
  • 电商网站开发平台pi netwo少儿培训
  • 山东济南网站建设公司女排联赛排名
  • 网站建设与推广长春软文素材库
  • 小说网站制作开源搭建网站的步骤和顺序
  • 做一个小程序seo的基本内容
  • 网站被黑了你会怎么想你该怎么做广州线下培训机构停课
  • 迪哥哪个网站上做游戏直播股票指数是什么意思
  • 在线设计网站排名免费的编程自学网站
  • 网页制作平台推荐seo关键词优化
  • 天水网站开发网站统计器
  • 淮阴区建设局网站新闻早知道
  • 青州做网站的公司网络营销策划书的结构是什么
  • 成都企业网站开发公司慧聪网seo页面优化
  • 网站设计专业公司价格百度登录入口百度
  • 中国建设交易信息网站营销案例
  • 重庆市建设工程节能中心网站电脑系统优化软件哪个好用
  • 做美食视频的网站有哪些seo综合查询接口