您好!
欢迎来到京东云开发者社区
登录
首页
博文
课程
大赛
工具
用户中心
开源
首页
博文
课程
大赛
工具
开源
更多
用户中心
开发者社区
>
博文
>
大数据 | ClickHouse在京东能源管理平台的实践
分享
打开微信扫码分享
点击前往QQ分享
点击前往微博分享
点击复制链接
大数据 | ClickHouse在京东能源管理平台的实践
京东科技IoT团队
2020-12-31
IP归属:未知
10270浏览
大数据
物联网
## 前言 ClickHouse是一款面向大数据场景下的OLAP数据库,相比于传统的基于Hadoop生态圈的OLAP大数据分析系统,ClickHouse具有极致的查询性能、轻量级的架构设计及维护简单等优势。目前社区活跃度高,业界应用实践日趋广泛。 ## 业务介绍 京东能源管理平台是京东IoT产品部面向政企客户推出的一款利用物联网、大数据和AI技术实现用能企事业单位对能源大数据进行采集、监测、分析和告警的能耗分析产品,旨在帮助客户实现节能减排,降低单位产品能耗。 <center>![业务逻辑](//img1.jcloudcs.com/developer.jdcloud.com/280fb667-2478-4fdb-9117-00f90b63cb5620201230210725.png)</center> 能源指标包括用电量、用水量和用天然气量,维度有时间维度(年、月、周、日、时)、厂家、车间、生产线类型、生产线、设备。针对这些指标和维度,提供了实时的数据多维分析与诊断服务。 ## 技术选型 对于数据指标的多维度分析场景,上世纪业界就提出了BI(商业分析)的概念。相较于OLTP(联机事务)系统,业界把此类面向BI的系统统称为OLAP(联机分析)系统。伴随着计算机软件技术的发展、从单机工具的少量数据分析(如Excel),到中等规模数据通过分析型关系数据库构建(如微软的SSAS)的OLAP,再到今日的大数据时代,海量数据的实时OLAP分析引擎,技术上的推陈出新,工具系统上百花齐放百家争鸣,各有优势,但大体上可以将它们从架构模式上划分为两大类: 1. MPP架构。MPP架构特点是服务将接收到的查询请求发送到每个计算节点,待计算节点计算完成后,通过一个节点将最终结果汇总在一起得到最终结果。典型实现如Presto、Impala、SparkSQL、Drill等。MPP架构的特点是支持灵活的数据模型,要达到较高性能对内存开销大。 2. 预计算系统。预计算的核心思想是利用空间换时间,通过深入业务理解,将需要查询的数据指标和维度组合进行预处理,将计算好的结果存入数据库并建立对应索引,实现查询加速。典型实现如Kylin、Druid。预计算系统特点是性能较高,但灵活性较差,一般对数据模型调整会涉及到历史数据的重跑,维护困难。 <center>![MPP v.s. 预计算](//img1.jcloudcs.com/developer.jdcloud.com/84fc9a30-784a-42de-bc5c-0b979006097320201230211807.jpg)</center> 从上表可知,目前业界还没有一个OLAP引擎能够同时兼顾性能和灵活性的要求,京东能源管理平台在做技术选型的时候,综合考虑了模型的灵活性、部署的难易程度、开发成本、可维护性以及是否适合云端部署等因素,最终决定使用基于MPP架构的ClickHouse作为我们的OLAP引擎。 ## ClickHouse的应用 ### 系统架构 京东能源管理平台主要是对各种表计(水表、电表、天然气表等)设备上报的计数进行多维度分析统计、AI诊断和出具能耗报表等。表计的原始数据通常都是累计值,如电量度数就是一个从电表安装以来,所有耗电量的一个累计。因此,我们在数据接入前会引入一个差分器对数据进行预处理,使得进入ClickHouse的指标数据变成可直接累加的指标,方便利用SQL对接ClickHouse实现多维的查询服务。架构图如下: <center>![核心逻辑](//img1.jcloudcs.com/developer.jdcloud.com/4d583a7c-8e85-42a2-9370-29bf16d6e1b420201230210840.png)</center> 说明: - 物管平台:对设备的管理,管理物模型及设备状态、采集设备数据。 - 消息总线:kafka消息队列,利用JSON格式数据实现物管平台和能源平台的数据交互。 - 差分器:对每次上报的累计值同上一次上报的累计值做差值计算,得到可累加指标。 - 异常规则链:提供一个异常规则集,用于差分器判定上报数据是否异常,如异常则进行记录,数据不作处理。 - OLAP引擎:基于ClickHouse实现的OLAP引擎。 - 多维分析服务:提供通用的数据多维分析查询服务,能够通过统一的API实现各种维度和指标的组合查询。 - 政府和企业界面:政企客户的WEB界面。 ### ClickHouse应用 通过上面的架构图可以看出,能源平台采用ClickHouse作为OLAP引擎提供多维查询服务。下面重点从数据的接入、存储以及通用化接口设计方面谈一谈ClickHouse的应用: - **数据接入** ClickHouse基于kafka引擎表的数据接入可以看做是一个典型的ETL过程,数据的抽取(Extract)是通过建立一张kafka引擎表,产生消费端订阅kafka topic实现;数据的转换(Transform)通过物化视图实现;数据最终加载(Load)进MergeTree表,实现实际数据存储。 <center>![ck](//img1.jcloudcs.com/developer.jdcloud.com/9cdf7e0e-9cb6-4e46-9130-451d6812dccb20201230210915.png)></center> 创建Kafka表示例: ```sql CREATE TABLE statistics_kafka ON CLUSTER '{cluster}' ( timestamp UInt64, level String, message String ) ENGINE = Kafka SETTINGS kafka_broker_list = 'kafka.jd.com:9092', kafka_topic_list = 'statistics', kafka_group_name = 'gp-st', kafka_format = 'JSONEachRow', kafka_skip_broken_messages = 1, kafka_num_consumers = 3; ``` - kafka_broker_list: kafka broker地址 - kafka_topic_list:消费的topic - kafka_group_name:消费groupId - kafka_format:数据格式JSONEachRow表示消息体为JSON格式 - kafka_skip_broken_messages:表示忽略的kafka异常消息条数,默认为0 - kafka_num_consumers:消费者个数,默认值为1,建议同kafka分区数对应 创建物化视图示例: ```sql CREATE MATERIALIZED VIEW statistics_view ON CLUSTER '{cluster}' TO statistics_replica AS SELECT timestamp, level, message FROM statistics_kafka; ``` 创建MergeTree引擎表示例: ```sql CREATE TABLE statistics_replica ON CLUSTER '{cluster}'{ timestamp UInt64, dt String, deviceId String, level String, message String } ENGINE = ReplicatedMergeTree('/clickhouse/tables/{shard}/statistics_replica','{replica}') PARTITION BY dt ORDER BY (dt,deviceId,level); ``` [^]: 本示例创建的是副本表,详细在存储部分讨论。 - **存储** 1. **ClickHouse表类型** 本地表:实际数据存储的表,如上示例表statistics_replica。 分布式表:一个逻辑上的表, 可以理解为数据库中的视图, 一般查询都查询分布式表. 分布式表引擎会将我们的查询请求路由本地表进行查询, 然后进行汇总最终返回给用户。创建分布式表示例: ```sql CREATE TABLE statistics ON CLUSTER '{cluster}' AS statistics_replica ENGINE = Distributed(ck_cluster_1,test,events_local,rand()); ``` 2. **Replication和Sharding** Replication是ClickHouse提供的副本机制,对于Replicated MergeTree 系列复制表,可以设置每个表有多份完全一样的数据存放在不同的计算节点上,每一份数据都是完整的,并且称为一个副本。 Shard:将表中的数据按照一定的规则拆分为多个部分,每个部分的数据均存储在不同的计算节点上,每个计算节点上的数据称为一个分片。 <center>![sTKd1jw5Q6uHCzl](//img1.jcloudcs.com/developer.jdcloud.com/c84ebdc4-9fcf-492f-b89d-6291be4d51a520201230211038.png)</center> ClickHouse基于Replicated MergeTree引擎与Zookeeper实现了复制表机制,在创建表时,可以决定表是否高可用。上一节的statistics_replica表,其中/clickhouse/tables/{shard}/statistics_replica表示Zookeeper中对应副本表的node。当数据写入ReplicatedMergeTree表时,过程如下: <center>![ReplicatedMergeTree数据写入过程](//img1.jcloudcs.com/developer.jdcloud.com/9851687e-8635-400a-91fc-61436367a7ba20201230210957.png)</center> 1. 某一个ClickHouse节点接收到数据写入请求。 2. 通过interserver HTTP port端口同步到其他实例。 3. 更新Zookeeper集群上的node信息。 **OLAP通用接口设计** ClickHouse提供标准的SQL查询引擎,通过JDBC引用程序可以实现多ClickHouse的基本操作。OLAP的常规操作如上卷、下钻和切片会涉及到多种维度自由组合、多种指标交叉剖析的过程,如果服务端采用Mybatis或JPA等常规ORM操作,工程师很容易根据不同的查询场景要求涉及出对应的接口,亦或是根据大量的分支操作设计出复杂的判定性接口,鉴于此,作者从[mdx](https://baike.baidu.com/item/MDX%E8%AF%AD%E5%8F%A5)思想获得启示,设计一套对OLAP优化的通用多维服务查询接口。 首先,一个典型的分析类SQL语句如下: ```sql SELECT day_str, factory_name, workshop_name, prodline_name, device_id, SUM(w_total) AS total FROM statistics WHERE day_str BETWEEN '2020-10-01' AND '2020-12-31' GROUP BY day_str,factory_name,workshop_name,prodline_name,device_id ORDER BY day_str ASC; ``` 如上语句,我们翻译成业务语言为『分别查询2020年4季度全厂所有设备的耗电量』,从这里我们可以清楚的知道这里的维度是指『设备名称』,指标为『耗电量』,基于此,可以进一步归类,维度通常出现在SQL语句的SELECT、WHERE、GROUP BY和ORDER BY后面,指标则通常出现在SELECT后面,也就是可以总结如下模式: ```sql SELECT {维度},{指标} FROM table_name WHERE {维度}='xxx' GROUP BY {维度} ORDER BY {维度}; ``` 因此,我们可以设计如下通用接口方法: ```java //通用方法 List<Map<String,Object>> queryStatisticsResult(Query query); //Query类 public class Query { private static final long serialVersionUID = 4904019884726531900L; /** * 维度 */ private List<String> dimensions; /** * 指标 */ private List<Measure> measures; /** * 过滤条件 */ private List<Filter> where; } //Measure类 public class Measure implements Serializable { private static final long serialVersionUID = -8556179136317748835L; /** * 指标名称 */ @NonNull private String name; /** * 列名 */ @NonNull private String field; /** * 聚合类型 */ @NonNull private AggregationEnum expression; } //聚合枚举 public enum AggregationEnum { SUM,AVG,COUNT,MIN,MAX,COUNT_DISTINCT,PERCENTILE; } ``` ## 总结 本文重点介绍了京东综合能源管理平台多维数据分析引擎的架构和设计,从数据接入、存储和多维分析服务设计的角度,阐述了ClickHouse的一种典型应用场景。希望通过本文让读者在应对大数据实时OLAP领域,提供一种思路和方法。当然,限于篇幅和本人水平有限,没有进一步展开阐述更多的可能性方案,随着我们对于业务的深入,系统的迭代升级,适宜于将来更优方案势必会步步推出,也请期待。 > 作者:樊思国
原创文章,需联系作者,授权转载
上一篇:畅谈 | 如何设计一个融合了组织和岗位的权限模型
下一篇:前端 |JavaScript基础之类
相关文章
产品推介 | 担心数据“裸奔”?数据加密服务帮你上一把安全锁
AAAI 2021论文:利用深度元学习对城市销量进行预测(附论文下载)
大数据 | ClickHouse在京东能源管理平台的实践
京东科技IoT团队
文章数
13
阅读量
110965
作者其他文章
01
前端 | 小程序横竖屏的坑和 rpx 布局方案
如何避免小程序开发过程中的那些“坑”
01
前端 | Chrome 80 中 Iframe cookie 无法携带的问题
Chrome 80 中 Iframe cookie 无法携带的问题求解过程。
01
NLU | 智能音箱语义理解——MDIS三合一模型
MDIS模型(Unified Model for Multiple Domain Intent and Slot)可以做到同时对话术进行领域分类、意图判断以及填槽。
01
前端 |数据大屏适配方案
数据大屏适配方案详解
京东科技IoT团队
文章数
13
阅读量
110965
作者其他文章
01
前端 | 小程序横竖屏的坑和 rpx 布局方案
01
前端 | Chrome 80 中 Iframe cookie 无法携带的问题
01
NLU | 智能音箱语义理解——MDIS三合一模型
01
前端 |数据大屏适配方案
添加企业微信
获取1V1专业服务
扫码关注
京东云开发者公众号