作者:Syn良子 出处:https://www.cnblogs.com/cssdongl/p/9588079.html 转载请注明出处

最近在学习和使用Druid.觉得一些章节有必要按照自己的理解翻译一下并分享出来,翻译不到位的地方欢迎指正.

Druid是什么?

Druid是一个为大规模数据集上进行高性能的交互分析而设计的("OLAP"式)的数据存储引擎.Druid经常用来作为数据存储来驱动基于GUI的分析方面的应用,也可以为需要快速聚合的应用提供高并发的后端API.Druid通常包含以下一些应用:

  • 点击流分析
  • 网络流量分析
  • 服务器指标存储
  • 应用性能指标
  • 数字市场分析
  • 商业智能/OLAP

Druid关键性的功能如下:

  1. 列式存储.Druid使用面向列的存储,这意味着它对一些特殊的查询仅仅需要加载相应的列就可以了.这能带来巨大的性能提升因为它仅仅需要查询很少的列.此外,它的每一列是按照它自己的独有的数据类型而进行过的优化存储,这样可以支持快速的扫描和聚合.
  2. 可扩展的分布式系统.Druid一般部署在成百上千的服务器上,它能够实现每秒百万级别的数据采集速率,以及万亿级别的数据记录存储以及亚秒级别的数据查询延迟
  3. 大规模并行式处理.Druid能够在整个集群上对查询进行并行处理.
  4. 实时的或者批处理的数据摄取.Druid能够实时的摄取数据(摄取的数据能够立刻被用来查询)或者以批处理的方式进行摄取。
  5. 自愈性,自平衡,容易管理.作为一个集群的管理者,很方便可以来扩大或者缩小集群的规模.对于后台来讲,简单的从集群上添加或者删除服务器不用停机集群自己就能够自动实现重新平衡.任意一个druid节点坏掉的话,集群自己就可以绕过坏点直到这些有问题的服务器被替换掉.Druid被设计成一个永不停机7*24小时无间断运行的集群,即使配置改变以及软件升级也不应该做为它停机的理由.
  6. 永远不会丢失数据的容错的云原生架构.一旦Druid已经摄取了数据,那么一个备份就会被拷贝到deep storage(这个存储方式可以是云存储,HDFS或者其他共享文件系统).如果单个Druid服务器失败那么能够从deep storage进行恢复.对于影响一部分druid服务器的有限故障,replication能够确保查询在服务器恢复的时候仍然是可能的
  7. 快速过滤的索引.Druid使用CONCISE或者Roaring压缩的位图索引来创建索引用于控制在多列上进行快速过滤和查询
  8. 近似算法.Druid包含一些近似count-distinct,近似排名,近似直方图和中位数这些近似算法.这些算法使用较少的内存但是通过能够提供比精确计算更快的速度.当然,对于那些要求精确比速度更重要的场景,druid仍然能够提供精确的计算和排名.
  9. 数据摄取预聚合.Druid支持在摄取数据的时候进行预聚合.这种对数据摄取的预聚合能够节省消耗以及提升性能.

何时使用Druid

如果你的case满足下面一些特征那么Druid应该是一个好的选择:

  • 插入数据的频次非常高,但是修改非常少
  • 你的大部分查询时聚合和报表查询(比如"group by"查询).当然你可以还有一些查找和扫描的查询
  • 你的意愿是希望查询延迟在100ms到几秒之间
  • 你的数据有时间的属性(Druid包含一些特殊的设计和优化对于时间序列)
  • 你可能有不止一个表,而且每个查询仅命中一些大的分布式的表.查询可能也会命中不止一个小的lookup表.
  • 你需要在一些高基数的列上面(比如URLS,user IDs)做一些快速的计算和排序
  • 你需要从Kafka,HDFS,flat files或者对象存储比如Amszon S3上加载数据

下面一些情况你可能不太适合用Druid:

  • 你需要对已经存在的记录利用主键进行低延迟的更新操作.Druid支持流式插入,但是不是更新(一般用后台的批处理任务来进行更新)
  • 你正在构建一个线下的报表系统而且对查询延迟不是非常在意
  • 你想做一些大的表的关联(比如连接大的事实表和另外一个大的事实表).

Druid学习之路 (一)Druid初识的更多相关文章

  1. Redis——学习之路四(初识主从配置)

    首先我们配置一台master服务器,两台slave服务器.master服务器配置就是默认配置 端口为6379,添加就一个密码CeshiPassword,然后启动master服务器. 两台slave服务 ...

  2. Redis——学习之路三(初识redis config配置)

    我们先看看config 默认情况下系统是怎么配置的.在命令行中输入 config get *(如图) 默认情况下有61配置信息,每一个命令占两行,第一行为配置名称信息,第二行为配置的具体信息.     ...

  3. Redis——学习之路二(初识redis服务器命令)

    上一章我们已经知道了如果启动redis服务器,现在我们来学习一下,以及如何用客户端连接服务器.接下来我们来学习一下查看操作服务器的命令. 服务器命令: 1.info——当前redis服务器信息   s ...

  4. Druid学习之路 (三)Druid的数据源和段

    作者:Syn良子 出处:https://www.cnblogs.com/cssdongl/p/9703204.html 转载请注明出处 Druid的数据源和分段 Druid的数据存储在"Da ...

  5. Druid学习之路 (五)Druid的数据摄取任务类型

    作者:Syn良子 出处:https://www.cnblogs.com/cssdongl/p/9885534.html 转载请注明出处 Druid的数据摄取任务类型 Druid支持很多种类型的数据摄取 ...

  6. Druid学习之路 (四)Druid的数据采集格式

    作者:Syn良子 出处:https://www.cnblogs.com/cssdongl/p/9715735.html 转载请注明出处 Druid的数据采集格式 Druid可以采集非标准化的数据诸如J ...

  7. Druid学习之路 (二)Druid架构

    作者:Syn良子 出处:https://www.cnblogs.com/cssdongl/p/9608812.html 转载请注明出处 Druid架构 Druid原本就设计为一个容易操作的面向云的多进 ...

  8. 我的Python学习之路 Python的初识与准备工作

    注:文笔不好,不喜勿喷,当个段子看看就好 一.初识Python 第一次听到Python是在2016年大概暑假 时候(即将大三),因为对黑客技术的蜜汁热爱(虽然自己并不会),在玄魂大大的公众微信号中看到 ...

  9. Redis——学习之路一(初识redis)

    在接下来的一段时间里面我要将自己学习的redis整理一遍,下面是我整理的一些资料: Redis是一款依据BSD开源协议发行的高性能Key-Value存储系统(cache and store),所以re ...

随机推荐

  1. jquery书写一个简易的二级联动

    先用php生成一个json数组示例如下 JSON_UNESCAPED_UNICODE 是对汉字进行处理的参数 然后HTML代码如下 把那个json_city赋值成我们用php生成的json即可 < ...

  2. 自动化测试环境准备robotframework

    (一)针对python2.7版本的自动化环境准备: python 下载地址: https://www.python.org/downloads/ 这里选择Python2.7系列的,后面涉及到wxPyt ...

  3. 第二十五篇:使用 sigaction 函数实现可靠信号

    前言 在前文中,讲述了一个可靠信号的示例.它分成几个步骤组成( 请参考前文 ).在 Linux 系统编程中,有个方法可以将这些步骤给集成起来,让我们使用起来更加的方便. 那就是调用 sigaction ...

  4. nmon工具

    下载地址 1.http://nmon.sourceforge.net/pmwiki.php?n=Site.Download tar xvzf  *.tar.gz,需要配置权限 chmod -x,同时配 ...

  5. Android 按Menu弹出菜单

    \res\anim\menu_in.xml    资源文件(动画) <?xml version="1.0" encoding="UTF-8"?> & ...

  6. jquery对象转dom对象

    jq取兄弟级的上移个元素 jquery对象: var a = $(this).prev("a"); console.log(a); 输出: 转dom对象: var a = $(th ...

  7. poj2396 Budget&&ZOJ1994 Budget[有源汇上下界可行流]

    Budget Time Limit: 5 Seconds      Memory Limit: 32768 KB      Special Judge We are supposed to make ...

  8. 【CF628D】Magic Numbers 数位DP

    [CF628D]Magic Numbers 题意:求[a,b]中,偶数位的数字都是d,其余为数字都不是d,且能被m整除的数的个数(这里的偶数位是的是从高位往低位数的偶数位).$a,b<10^{2 ...

  9. java的Enumeration转list

    java的Enumeration转list Enumeration<String> attrs = getAttrNames();// while(attrs.hasMoreElement ...

  10. 单台centos7.3 虚拟机实现主从复制和哨兵集群

    环境: centos7.3一台 部署图: 从服务器配置: slaveof 哨兵配置: port sentinel monitor m1 127.0.0.1 6379 2 sentinel monito ...