查询是发送HTTP请求到,Broker, Historical或者Realtime节点。查询的JSON表达和每种节点类型公开相同的查询接口。

Queries are made using an HTTP REST style request to a Broker, Historical, or Realtime node. The query is expressed in JSON and each of these node types expose the same REST query interface.

We start by describing an example query with additional comments that mention possible variations. Query operators are also summarized in a table below.

Example Query "rand"

Here is the query in the examples/rand subproject (file is query.body), followed by a commented version of the same.

{
  "queryType":
"groupBy",
  "dataSource":
"randSeq",
  "granularity": "all",
  "dimensions": [],
  "aggregations": [
    { "type":
"count", "name": "rows" },
    { "type":
"doubleSum", "fieldName": "events",
"name": "e" },
    { "type":
"doubleSum", "fieldName": "outColumn",
"name": "randomNumberSum" }
  ],
  "postAggregations":
[{
     "type":
"arithmetic",
     "name":
"avg_random",
     "fn":
"/",
     "fields": [
       { "type":
"fieldAccess", "fieldName": "randomNumberSum"
},
       { "type":
"fieldAccess", "fieldName": "rows" }
     ]
  }],
  "intervals":
["2012-10-01T00:00/2020-01-01T00"]
}

This query could be
submitted via curl like so (assuming the query object is in a file
"query.json").

curl -X POST "http://host:port/druid/v2/?pretty"
-H 'content-type: application/json' -d @query.json

The
"pretty" query parameter gets the results formatted a bit nicer.

Details of Example Query "rand"

The queryType JSON
field identifies which kind of query operator is to be used, in this case it is
groupBy, the most frequently used kind (which corresponds to an internal
implementation class GroupByQuery registered as "groupBy"), and it
has a set of required fields that are also part of this query. The queryType
can also be "search" or "timeBoundary" which have similar
or different required fields summarized below:

{
  "queryType":
"groupBy",

The dataSource JSON
field shown next identifies where to apply the query. In this case, randSeq
corresponds to the examples/rand/rand_realtime.spec file schema:

"dataSource": "randSeq",

The granularity JSON
field specifies the bucket size for values. It could be a built-in time
interval like "second", "minute",
"fifteen_minute", "thirty_minute", "hour" or
"day". It can also be an expression like {"type":
"period", "period":"PT6m"} meaning "6 minute
buckets". See Granularities
for more information on the different options for this field. In this example,
it is set to the special value "all" which means bucket all data points
together into the same time bucket

"granularity": "all",

The dimensions JSON
field value is an array of zero or more fields as defined in the dataSource
spec file or defined in the input records and carried forward. These are used
to constrain the grouping. If empty, then one value per time granularity bucket
is requested in the groupBy:

"dimensions": [],

A groupBy also
requires the JSON field "aggregations" (See Aggregations), which
are applied to the column specified by fieldName and the output of the
aggregation will be named according to the value in the "name" field:

"aggregations": [
    { "type":
"count", "name": "rows" },
    { "type":
"doubleSum", "fieldName": "events",
"name": "e" },
    { "type":
"doubleSum", "fieldName": "outColumn", "name":
"randomNumberSum" }
  ],

You can also specify
postAggregations, which are applied after data has been aggregated for the
current granularity and dimensions bucket. See Post Aggregations
for a detailed description. In the rand example, an arithmetic type operation
(division, as specified by "fn") is performed with the result
"name" of "avg_random". The "fields" field
specifies the inputs from the aggregation stage to this expression. Note that
identifiers corresponding to "name" JSON field inside the type
"fieldAccess" are required but not used outside this expression, so
they are prefixed with "dummy" for clarity:

"postAggregations": [{
     "type":
"arithmetic",
     "name":
"avg_random",
     "fn":
"/",
     "fields": [
       { "type":
"fieldAccess", "fieldName": "randomNumberSum"
},
       { "type":
"fieldAccess", "fieldName": "rows" }
     ]
  }],

The time range(s) of
the query; data outside the specified intervals will not be used; this example
specifies from October 1, 2012 until January 1, 2020:

"intervals":
["2012-10-01T00:00/2020-01-01T00"]
}

Query Operators

The following table
summarizes query properties.

Properties shared by
all query types

property

description

required?

dataSource

query is applied to
this data source

yes

intervals

range of time
series to include in query

yes

context

This is a key-value
map used to alter some of the behavior of a query. See Query Context
below

no

query type

property

description

required?

timeseries, topN,
groupBy, search

filter

Specifies the
filter (the "WHERE" clause in SQL) for the query. See Filters

no

timeseries, topN,
groupBy, search

granularity

the timestamp
granularity to bucket results into (i.e. "hour"). See Granularities for
more information.

no

timeseries, topN,
groupBy

aggregations

aggregations that
combine values in a bucket. See Aggregations.

yes

timeseries, topN,
groupBy

postAggregations

aggregations of
aggregations. See Post
Aggregations
.

yes

groupBy

dimensions

constrains the
groupings; if empty, then one value per time granularity bucket

yes

search

limit

maximum number of
results (default is 1000), a system-level maximum can also be set via
com.metamx.query.search.maxSearchLimit

no

search

searchDimensions

Dimensions to apply
the search query to. If not specified, it will search through all dimensions.

no

search

query

The query portion
of the search query. This is essentially a predicate that specifies if
something matches.

yes

Query Context

property

default

description

timeout

0 (no timeout)

Query timeout in
milliseconds, beyond which unfinished queries will be cancelled

priority

0

Query Priority.
Queries with higher priority get precedence for computational resources.

queryId

auto-generated

Unique identifier
given to this query. If a query ID is set or known, this can be used to
cancel the query

useCache

true

Flag indicating
whether to leverage the query cache for this query. This may be overriden in
the broker or historical node configuration

populateCache

true

Flag indicating
whether to save the results of the query to the query cache. Primarily used
for debugging. This may be overriden in the broker or historical node
configuration

bySegment

false

Return "by
segment" results. Pimarily used for debugging, setting it to true
returns results associated with the data segment they came from

finalize

true

Flag indicating
whether to "finalize" aggregation results. Primarily used for
debugging. For instance, the hyperUnique aggregator will return the full
HyperLogLog sketch instead of the estimated cardinality when this flag is set
to false

Query Cancellation

Queries can be
cancelled explicitely using their unique identifier. If the query identifier is
set at the time of query, or is otherwise known, the following endpoint can be
used on the broker or router to cancel the query.

DELETE
/druid/v2/{queryId}

For example, if the
query ID is abc123, the query can be cancelled as follows:

curl -X DELETE "http://host:port/druid/v2/abc123"

druid查询的更多相关文章

  1. Druid 查询超时配置的探究 → DataSource 和 JdbcTemplate 的 queryTimeout 到底谁生效?

    开心一刻 昨晚跟我妈语音 妈:我年纪有点大了,想抱孩子了 我:妈,我都多大了,你还想抱我? 妈:我想抱小孩,谁乐意抱你呀! 我:刚好小区有人想找月嫂,要不我帮你联系下? 妈:你给我滚 然后她直接把语音 ...

  2. 【转载】DRuid 大数据分析之查询

    转载自http://yangyangmyself.iteye.com/blog/2321759 1.Druid 查询概述     上一节完成数据导入后,接下来讲讲Druid如何查询及统计分析导入的数据 ...

  3. Druid.io系列(五):查询过程

    原文链接: https://blog.csdn.net/njpjsoftdev/article/details/52956194 Druid使用JSON over HTTP 作为底层的查询语言,不过强 ...

  4. Druid 0.17入门(4)—— 数据查询方式大全

    本文介绍Druid查询数据的方式,首先我们保证数据已经成功载入. Druid查询基于HTTP,Druid提供了查询视图,并对结果进行了格式化. Druid提供了三种查询方式,SQL,原生JSON,CU ...

  5. Druid学习之查询语法

    写在前面 最近一段时间都在做druid实时数据查询的工作,本文简单将官网上的英文文档加上自己的理解翻译成中文,同时将自己遇到的问题及解决方法list下,防止遗忘. 本文的demo示例均来源于官网. D ...

  6. 快速了解Druid——实时大数据分析软件

    Druid 是什么 Druid 单词来源于西方古罗马的神话人物,中文常常翻译成德鲁伊.  本问介绍的Druid 是一个分布式的支持实时分析的数据存储系统(Data Store).美国广告技术公司Met ...

  7. druid.io 海量实时OLAP数据仓库 (翻译+总结) (1)

    介绍 我是NDPmedia公司的大数据OLAP的资深高级工程师, 专注于OLAP领域, 现将一个成熟的可靠的高性能的海量实时OLAP数据仓库介绍给大家: druid.io NDPmedia在2014年 ...

  8. druid.io 海量实时OLAP数据仓库 (翻译+总结) (1)——分析框架如hive或者redshift(MPPDB)、ES等

    介绍 我是NDPmedia公司的大数据OLAP的资深高级工程师, 专注于OLAP领域, 现将一个成熟的可靠的高性能的海量实时OLAP数据仓库介绍给大家: druid.io NDPmedia在2014年 ...

  9. [转帖]OLAP引擎这么多,为什么苏宁选择用Druid?

    OLAP引擎这么多,为什么苏宁选择用Druid? 原创 51CTO 2018-12-21 11:24:12 [51CTO.com原创稿件]随着公司业务增长迅速,数据量越来越大,数据的种类也越来越丰富, ...

随机推荐

  1. Unbutu14.04 切换ROOT用户后无法启用音频

    系统环境: Ubuntu14.04 x64 问题描述: 今天安装了Ubuntu14.04的64位系统,启用root用户登录后,观看视频时出现没有声音的现象. 问题原因: Ubuntu安装后默认root ...

  2. thinkphp join加别名

    //此段代码在某个Model里面$tbpre = $this->tableprefix;$Aaa = M('aaa');$Aaa->table(array("{$tbpre}aa ...

  3. Triangle Problems

    Triangle Problem songxiuhuan 宋修寰 Import the Junit and eclemma Choose the project and right click, ch ...

  4. 购买的wemall 6.0商城系统源码分享

    使用方法 1.解压目录 2.cd wemall6 && npm i 3.配置config下的config.json 4.npm start 摒弃以往的开发框架thinkphp,使用no ...

  5. node.js爬虫爬取拉勾网职位信息

    简介 用node.js写了一个简单的小爬虫,用来爬取拉勾网上的招聘信息,共爬取了北京.上海.广州.深圳.杭州.西安.成都7个城市的数据,分别以前端.PHP.java.c++.python.Androi ...

  6. android studio 中的 gradle version

    刚开始接触AS,从geithub上download了好多项目,每一个都需要改动,对我这种新手来说,慢慢琢磨吧 问题一: 解决办法: 在build.gradle中,将gradle的版本改正如上图所示即可 ...

  7. Redis-port安装使用实现redis迁移codis,以及简单redis pipe实现将mysql迁移redis

    (0)Redis-port原理: 首先是看到下面这篇文档开始研究的redis-port http://www.itnpc.com/news/web/146085373656602.html  简要截图 ...

  8. 字符集&各种编码&编码解码

    要理解乱码问题,首先需要理解几个概念:字符集.编码.编码规则.乱码 1. 字符集: 字符(Character)是各种文字和符号的总称,包括各国家文字.标点符号.图形符号.数字等.字符集(Charact ...

  9. Android使用ADB命令和stetho查看app数据库

    一.使用ADB命令查看 打开命令窗口,进入Android SDK目录下的platform-tools,执行命令: 1.输入:在windows下: adb shell 在linux下: ./adb sh ...

  10. (转)Nginx + uwsgi + web.py + MySQLdb

    一.背景知识: Web服务器上有多种方式运行Python: 传统上的CGI方式:基本已被淘汰 mod_python的模块方式:仍在广泛使用,但生产环境中也被逐步淘汰 uwsgi方式:目前生产环境下最受 ...