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

做网站 信科网站建设便宜代做作业网站

做网站 信科网站建设便宜,代做作业网站,中小企业建站,做基因功能注释的网站目录 1、kudu的定位 2、kudu基本概念 3、存储架构 3.1 储存架构#xff1a;Tablet 3.2 储存架构#xff1a;RowSets 3.3 储存架构#xff1a;DiskRowSets 4、kudu工作原理 4.1 Compaction 4.2 Tablet切分规则 4.3 kudu写过程#xff1a;insert 4.4 kudu写过程Tablet 3.2 储存架构RowSets 3.3 储存架构DiskRowSets 4、kudu工作原理 4.1 Compaction 4.2 Tablet切分规则 4.3 kudu写过程insert 4.4 kudu写过程update 4.5 Kudu读过程 1、kudu的定位 HDFS: 存储格式Textfile,Parquet,ORC适合离线分析不支持单条记录级别的update操作随机读写性能差。 HBASE :可以进行高效随机读写但写快读慢大批量数据获取时的性能较差。并不适用于基于SQL的数据分析方向。 Kudu 批量更新和单条记录更新都很友好  --FastData 与Impala组合使用OLAP性能强大  --FastAnalytics 高可用 动态扩展 2、kudu基本概念 Table表一张table是数据存储在kudu的位置。Table具有schema和全局有序的primarykey(主键)。 Tablet(段)一个tablet是一张table连续的segment与其他数据存储引擎或关系型数据的partition相似。Tablet存在副本机制其中一个副本为leadertablet。任何副本都可以对读取进行服务并且写入时需要在所有副本对应的tabletserver之间达成一致性。 Tabletserver存储tablet和为tablet向client提供服务。对于给定的tablet一个tabletserver充当leader其他tabletserver充当该tablet的follower副本。只有leader服务写请求leader与follower为每个服务提供读请求。 Master主要用来管理元数据(元数据存储在只有一个tablet的catalogtable中)即tablet与表的基本信息监听tserver的状态 CatalogTable: 元数据表用来存储table(schema、locations、states)与tablet现有的tablet列表每个tablet及其副本所处tservertablet当前状态以及开始和结束键的信息。 3、存储架构 •MemRowSet 用于新数据insert及已在MemRowSet中的数据的更新一个MemRowSet写满后会将数据刷到磁盘形成若干个DiskRowSet。(默认是1G或者或者120S) •DiskRowSet 用于老数据的变更mutation后台定期对DiskRowSet做compaction以删除没用的数据及合并历史数据减少查询过程中的IO开销。 •BloomFile 根据一个DiskRowSet中的key生成一个bloomfilter用于快速模糊定位某个key是否在DiskRowSet中存在。 •Ad_hocIndex 主键的索引用于定位key在DiskRowSet中的具体哪个偏移位置。 •BaseData MemRowSet flush下来的数据按列存储按主键有序。 •UndoFile 基于BaseData之前时间的历史数据通过在BaseData上applyUndoFile中的记录可以获得历史数据。 •RedoFile 基于BaseData之后时间的变更mutation记录通过在BaseData上applyRedoFile中的记录可获得较新的数据。  •DeltaMem 用于DiskRowSet中数据的变更mutation先写到内存中写满后flush到磁盘形成RedoFile。 3.1 储存架构Tablet 分区策略 Writes Reads Tablet Growth Range 所有写入都会落到最新分区 可以通过分区键提高读能力 可添加新tablets Hash 在tablets上均匀分布 可以通过分区键提高读能力 tablets会无限增长 Hash分区有利于提高写吞吐量Range分区可避免tablet无限增长问题所以我们可以使用多级分区组合这两种分区方式 3.2 储存架构RowSets Tablet在底层被进一步细分成了一个称之为RowSets的单元 •MemRowSet 用于新数据insert及已在MemRowSet中的数据的更新一个MemRowSet写满后会将数据刷到磁盘形成若干个DiskRowSet。(默认是1G或者或者120S) •DiskRowSet 用于老数据的变更mutation后台定期对DiskRowSet做compaction以删除没用的数据及合并历史数据减少查询过程中的IO开销。 3.3 储存架构DiskRowSets DiskRowSet分为了两部分basedata、deltastores。basedata 负责存储基础数据deltastores负责存储 basedata 中的变更数据 4、kudu工作原理 4.1 Compaction 由于所有插入的数据都是先写入memRowSet到达一定条件后再写入DiskRowSet而且DiskRowSet中的basedata是不变的这就导致会出现数据重叠的现象导致写或查询时需要搜索大量的DiskRowSet 三种Compaction策略 DiskRowSet Compaction减少DiskRowSet数量优化insert、update和scans时间。 Minor Delta Compaction只减少delta file数量优化scans时间。 Major Delta Compaction对base data和delta file进行compaction优化scans时间 4.2 Tablet切分规则 建表时指定分区策略 Hash Partitioning哈希分区通过哈希值将行分配到某一个bucket每个bucket对应一个tablet建表时设置bucket的数量。 Range Partitioningrange partition使用完全有序的分区键来分配行分区键必须是kudu表主键的子集。 DEMO: CREATE TABLE cust_behavior ( _id BIGINT PRIMARY KEY, skuSTRING, rating INT, fulfilled_dateBIGINT ) PARTITION BY RANGE(_id) ( PARTITION VALUES 1439560049342, PARTITION1439560049342 VALUES 1439566253755, PARTITION1439566253755 VALUES 1439572458168, PARTITION1439572458168 VALUES 1439578662581, PARTITION1439578662581 VALUES 1439584866994, PARTITION1439584866994 VALUES 1439591071407, PARTITION1439591071407 VALUES ) STORED AS KUDU; 4.3 kudu写过程insert Kudu与HBase不同Kudu将写入操作分为两种一种是插入新数据另一种是更新数据 1、客户端连接Master获取表的相关信息包括分区信息表中所有tablet的信息 2、客户端找到负责处理读写请求的tablet所负责维护的TServer。Kudu接受客户端的请求检查请求是否符合要求表结构 3、Kudu在Tablet中的所有rowsetmemrowset,diskrowset中进行查找看是否存在与待插入数据相同主键的数据如果存在就返回错误否则继续 4、Kudu在MemRowset中写入一行新数据在MemRowset数据达到一定大小时MemRowset将数据落盘并生成一个diskrowset用于持久化数据还生成一个memrowset继续接收新数据的请求。 4.4 kudu写过程update 4.5 Kudu读过程 1、客户端连接Master获取表的相关信息包括分区信息表中所有tablet的信息 2、客户端找到需要读取的数据的tablet所在的TServerKudu接受读请求并记录timestamp信息如果没有显式指定那么表示使用当前时间 3、Kudu找到待读数据的所有相关信息当目标数据处于memrowset时根据读取操作中包含的timestamp信息将该timestamp前提交的更新操作合并到base data中这个更新操作记录在该行数据对应的mutation链表中 4、当读取的目标数据位于diskrowset中在所有DeltaFile中找到所有目标数据相关的UNDO record和REDO recordsREDO records可能位于多个DeltaFile中根据读操作中包含的timestamp信息判断是否需要将base data进行回滚或者利用REDO records将base data进行合并更新。 整理不易一键三连可好。
http://www.pierceye.com/news/555544/

相关文章:

  • 石景山区网站建设网线制作方法及步骤
  • 做网站端口内容无法替换做微信公众号网站
  • 电商网站首页怎么制作做网站用什么语言高效
  • 广州自助建设网站平台天津做网站美工
  • js 捕获网站异常插件网站商城怎么做
  • 北辰网站开发淮北哪有做淘宝网站
  • 建设银行e路通网站室内设计师证需要学哪些课程
  • 舟山市建设信息港网站打不开如何建设一个收费的影视图文网站
  • 内蒙建设信息网站网页制作作品阐述
  • 天津网站seo策划服装定制项目计划书
  • 常州网站建设大全买奢侈品代工厂做的产品的网站名
  • 建设网站如入什么费网站建设体会doc
  • 不备案怎么做淘宝客网站吗深圳华强北新闻最新消息今天
  • 梅兰商贸网站开发设计外国网站在中国做推广
  • 有无专门做网站会员人数迅速增加的方法北京单页营销型网站
  • 岳阳网站开发网站运营怎么做建设网站设计
  • 能打开各种网站的浏览器下载合集建设农产品网络营销网站
  • 陕西网站建设方案优化如何做网站挂qq
  • 无锡市网站WordPress分类id在哪
  • 网站建设金网站建设 需求模板
  • 提高网站转化率营销网站制作都选ls15227
  • 一级页面的网站怎么做爱疯卷网站怎么做
  • 网站企业快速备案大气的企业网站
  • 一个好的网站建设微网站手机制作
  • 广州市做民宿什么网站比较好图盛网站建设
  • 深圳做网站佰达科技二十七易语言做网站源码
  • 水禾田网站建设公司南沙区做网站
  • 江西赣州网站上海企业服务云电话
  • 洱源网站建设品牌名字大全
  • 网站建设阶段要做什么帝国cms对比WordPress