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

佛山 网站建设培训班网站设计鉴赏

佛山 网站建设培训班,网站设计鉴赏,wordpress 音乐下载主题,一级门户网站建设费用前言在集群情况下,数据写入可以有写本地表和写分布式表2种方案,但是面向集群查询时,只能通过Distributed表引擎实现。本文主要介绍分布式查询多副本的路由规则。该配置项为:load_balancerandom/nearest_hostname/in_order/first_o…

前言

在集群情况下,数据写入可以有写本地表和写分布式表2种方案,但是面向集群查询时,只能通过Distributed表引擎实现。

本文主要介绍分布式查询多副本的路由规则。

该配置项为:load_balance=random/nearest_hostname/in_order/first_or_random

一、多副本的路由规则

查询数据时,如果一个分片shard有多个副本repIica,那么Distributed表引擎就需要面对副本选择的问题,选择查询究竟在哪个副本上执行。ck的负载均衡算法有以下四种:

  • random

  • nearest_hostname

  • in_order

  • first_or_random

  1. random

这是默认的负载均衡算法。在ck的服务节点中,有一个errors_count全局计数器,当服务发生任何异常时,技术器加1。randdom算法会选择errors_count最小的那个repIica,如果多个repIica的errors_count相同,则在这几个里随机选择一个。

  1. nearest_hostname

选择errors_count最小的那个,如果多个errors_count相同,则选择集群配置中host名称和当前host名称最相似的那个。相似比较的规则是与当前host的名称,按字节进行逐位对比,找到不同字节最少的那个。

例如当前host是a.bc.de,那么,a.bc.df就比a.bf.hh要更加相似。

a.bc.de

a.bc.df

a.bf.hh

  1. in_order

选择errors_count最小的那个,如果多个errors_count相同,则按照集群配置顺序选择。

  1. first_or_random

选择errors_count最小的那个,如果多个errors_count相同,则按照集群配置顺序选择第一个,如果第一个不可用,则随意选择一个其他的。

总结起来:其实这4个负载算法中,都是优先选择errors_count最小的那个,如果多个errors_count相同时,再根据不同的负载算法来选择。

拓展:对于集群的每一个查询,errors_count 都会更新一次,但 estimated_recovery_time 会根据需求重新计算,所以可能会出现这样的情况,当 errors_count 非零、estimated_recovery_time 为零时,下次查询会把 errors_count 置为零,并且尝试使用副本,就好像没有错误一样。

二、如何设置errors_count,确保生效

errors_count默认不开启

Hedged requests for remote queries. When setting use_hedged_requests enabled (off by default), allow to establish many connections with different replicas for query. New connection is enabled in case existent connection(s) with replica(s) were not established within hedged_connection_timeout or no data was received within receive_data_timeout. Query uses the first connection which send non empty progress packet (or data packet, if allow_changing_replica_until_first_data_packet); other connections are cancelled. Queries with max_parallel_replicas > 1 are supported. #19291 (Kruglov Pavel). This allows to significantly reduce tail latencies on very large clusters.

翻译:

远程查询的对冲请求。当将use_hedged_requests设置为启用(默认情况下为禁用)时,允许与不同副本建立多个连接以进行查询。如果在hedged_connection_timeout内未建立与副本的现有连接或在receive_data_timeout中未接收到数据,则启用新连接。查询使用发送非空进度包(或数据包,如果allow_changing_replica_until_first_data_packet)的第一个连接;其他连接被取消。支持max_paralle_replicas>1的查询。这允许在非常大的集群上显著减少尾部延迟。

使用场景:若将一个CK集群中的某个分片的某个副本停服(或者挂起),使之处于一个假死状态,无法对外提供服务,无法接受插入、查询请求等;如果未设置use_hedged_requests=1,还是会有1/副本数 的概率往停服的副本上发送,从而导致请求超时报错等问题

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

相关文章:

  • 昭通网站建设公司中国建设银行官方网站企业
  • 手机网站模板单页先做网站还是先解析
  • 青岛中小企业建设网站有扶持资金吗微信wap网站开发
  • 锦州网站开发外贸公司如何做公司网站
  • 公司网站的建设内容怎么写营销网站建设实训总结
  • 怎样简单做网站tvc广告片制作公司
  • 自己如何做一个网站网站链接分析工具
  • 建站公司郑州龙岗网站设计公司价格
  • 网站网络营销公司最新网站推广
  • 网页设计和网站开发有什么区别爬虫科技网站建设
  • 平面设计师必去的网站网站建设的要求及标准
  • 购物网站设计的目的甘肃省住房和城乡建设厅注册中心网站
  • 兼职网站制作电商网站如何提高转化率
  • 网站建设补充协议模板淘宝的网站建设情况
  • h5游戏平台代理seo关键词排名优化手机
  • 有名的网站制作公司成都网站建设索q479185700
  • 网站技术部做什么西昌有做网站的公司吗
  • 德国的网站后缀软件开发工程师是前端还是后端
  • asp 网站权限设计广州建设营销型网站
  • 怎样可以查到做网站公司上海互联网企业
  • 鹤壁网站开发茂名做网站的公司
  • 网页设计网络培训站长工具的使用seo综合查询排名
  • 株洲网站建设的公司网站前端建设都需要什么问题
  • 网站推广方案策划案例旅游网站建设策划方案
  • 网站搜索算法软件技术有限公司
  • 网站开发会计处理门户网站 建设商 排名
  • 做网站如何大网页临沂网站公众号建设
  • 网站设计制作费用手机设计房子的软件
  • 贾汪微网站开发垂直类网站怎么做推广
  • 厦门外贸商城网站建设综合服务门户网站建设