性能、稳定性、反压、Exactly Once,Jstorm开源最佳实践全解析

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: 在2017年在线技术峰会——阿里开源项目最佳实践上,来自阿里巴巴中间件的技术专家卫乐分享了Jstorm开源最佳实践。他主要介绍了Jstorm的架构,从性能、稳定性、监控系统、大规模部署、反压、灰度发布&热升级、Exactly-Once、新的窗口机制等方面详细扥想了Jstorm做的优化。

2017年在线技术峰会——阿里开源项目最佳实践上,来自阿里巴巴中间件的技术专家卫乐分享了Jstorm开源最佳实践。他主要介绍了Jstorm的架构,从性能、稳定性、监控系统、大规模部署、反压、灰度发布&热升级Exactly-Once、新的窗口机制等方面详细扥想了Jstorm做的优化。以下内容根据直播视频整理而成。


关于阿里中间件,欢迎访问官网了解更多:https://www.aliyun.com/aliware


视频回顾:点击进入

Pdf下载:点击进入

 

发展历史

 0ac46ad3e78c0313cf964dbc3d87d061a8d95d35

JStorm2013年开始开发,历经了25个版本。从2014年“双十一”开始,做了管控平台,包括调度、用户自定义日志等特征。2015年的“双十一”,对调度进行了优化,并且增加了反压功能,重新设计了Topology Master。2016年,除了性能优化之外,还提供了Exactly Once,包括把社区的Sliding Window和Shade Dependency等特性都移植到JStorm,此外还提供了很多新的feature,如重构的窗口机制,灰度发布等

使用场景

Jstorm在阿里集团、蚂蚁、优酷、土豆、高德都使用非常广泛。有三种部署方式:StandaloneJStorm-on-YARNJStorm-on-docker(主推,可以一键部署,扩容缩容方便)。

Jstorm已经不是简单的实时计算了,其应用在很多场景:

  • 反欺诈:Nut/Velocity
  • 审计:阿里妈妈广告/P4P,AMG
  • 数据统计分析:Eagleeye,AE,BI
  • 监控:Tlog(阿里内部监控)Rds-monitorSQL监控),Oceanbase-monitorSQL监控), Cainiao Radar, YunOSMonitor
  • 数据同步:RDS-Log-Sync, Unify-Log
  • 实时推荐:Alipay 1315, Alipay Hyperloop, TPP
  • 应用调度:AE邮件实时分析,网销宝

架构

961320f865645c6b2370bae6132d5309380113c6 

JStorm的整体架构如上图所示。最下方是部署模式,JStorm Core是JStorm计算框架本身,其上是Raw Storm API(此接口相对底层)、Exactly Once、Extension API。其上是集团内部广泛使用的Plugin,SQL engine上是应用。最右边是管控平台Koala。

JStorm增强

性能

27de119b1e321679013aaf9f331122baa4be9cdf 

上图是去年JStorm 2.2.0和Storm 1.0.2的性能对比图。硬件是32CPU Core/128G物理机,每个Worker是6G内存。从图中可以看到在不同的Worker已经不同的并发下,JStorm至少是Storm两倍以上的性能。那么,如何进行的性能优化?

29800dd135fbbccb22688a0b20de6e0cca5e2d48 

性能优化在现代的流处理领域广泛认可的一种方式是做Batch,Batch对性能优化的影响是非常大的。Batch是将消息打包,从上游接收一些消息,处理完后进行Batch再往下发,能够节省很多资源,提高性能。在此基础上进行了路径优化,即对JStorm做了JVM层面的Profile,检测框架的hot function部分(调用比较多的部分),进行针对性优化。虽然对JStorm进行了重构Metrics体系,但是底层的Metrics Core库并没有优化,所以对Meter,Histogram等进行了优化。此外,在序列化方面,对常用的序列化都进行了调优。

稳定性

49ce873fdf4832fbdc7982a097c330d6c8ad38c6 

在稳定性方面,做了以下优化:

多集群部署方面,由于涉及到异地多机房、同城多机房等问题,所以同城方面使用了ZK做多机房的容灾,JStorm自动把这些作业调到别的机房,只要保证别的机房的Worker量可以支撑作业量就不会出现问题。跨城情况相对复杂,成本也比较高,在阿里使用多链路来解决,即在多城市部署一模一样的集群消费同一份数据,在输出上做一些灾备,输出到不同的异构数据输出中,这样任意一条链路挂掉就能实时切换。

隔离方面,standalone提供了天然的隔离性,因为Docker本身用cgroup做资源隔离,所以jstorm-on-docker的隔离也相对简单。jstorm-on-yarn是在yarn上的Container中开启cgroup来做隔离。

HA方面,JStormHA是很早的特性,非常稳定。节点自检是checkhealth,用于检查supervsior。脚本会在supervsior压力过大或者内存快满的情况下自动调整可用Worker数(降低)。

监控方面,JStorm的自定义metrics重新实现,管控平台Koala集成了监控报警。Tuple life style能够根据节点间花费的时间得知拓扑结构中比较慢的环节。

升级/降级方面,降级即JStorm的反压,升级即热部署和灰度发布。

监控系统

423cde6f9e70c528db42dcda42fa55aa57ab196a 

Jstorm的监控系统如上图所示,重新设计的监控系统的优点在于自动聚合的功能。从下往上,一个Task有多个Stream,Task往上是Component,再往上是Topology,再往上是Cluster。重新设计后的优点在于可以统计所有级别的Metrics,展现完整的历史曲线,而不是单点的数据。

自定义监控

f22cc839d871829bdc1cae2fe207a5d7728f2f21 

上图是Metrics整个分级汇总的实现。具体可见github源码中最新的metrics设计文档。

大规模部署

54bed8a9780e6ddfb8385cff83ab350bae04b720 

在没有Topology Master的情况下,所有的Task汇报心跳、发送Metrics的时候都需要写ZK,并且Storm是把Metrics直接ZK里面,这样ZK的压力更大。有了Topology Master之后,Topology MasterTask的总节点,Task汇报心跳的时候只需要向Task汇报心跳,Topology Master汇总后再发送给Nimbus或者ZK,这样会使ZK的压力缩到拓扑的量级。

反压

Storm的反压,比如bolt处理消息来不及的情况下会向ZK写一个节点进行反压,监听bolt上游的节点停止发送数据直到下游的bolt能够正常处理。这样的问题是数据可能出现骤降的过程,并且反压结束数据流下来之后容易导致新一次的反压,从而导致tps会一直抖动。

ba986366af2dab10ba6558236cefd7ff83075d2c 

Jstorm做了两级的反压,第一级和Jstorm类似,通过执行队列来监测,但是不会通过ZK来协调,而是通过Topology Master来协调。在队列中会标记high water mark和low water mark,当执行队列超过high water mark时,就认为bolt来不及处理,则向TM发一条控制消息,上游开始减慢发送速率,直到下游低于low water mark时解除反压。此外,在Netty层也做了一级反压,由于每个Worker Task都有自己的发送和接收的缓冲区,可以对缓冲区设定限额、控制大小,如果spout数据量特别大,缓冲区填满会导致下游bolt的接收缓冲区填满,造成了反压。

灰度发布&热升级

3c7275ccfc25a79a558cc0a34f9b59b275630612 

一个规模很大的拓扑,以前的升级需要先把拓扑kill掉,修改代码、重新打包、重新提交,导致应用会有短暂的时间不能使用。此外,有时候只想升级部分的Worker,不想重启整个拓扑。灰度发布和热升级是做Worker内部的重启,但是不会kil拓扑。

Exactly-Once

ece338b41500baccac5a82f0fc3f6fec97ff03e2 

Jstorm中,Exactly-Once是通过Topology Master来做协调的。Jstorm中的Exactly-Once并不像以前那样每发一条消息一次。Spout发一个Batch,会有一个Batch ID,并且立马发一个Checkpoint barrier(控制消息),TM会得知发了一条新的Batch,TM会把offset记录下来。Bolt分为两种,一种是Stateless Bolt,一种是Stateful Bolt。Stateless Bolt比较简单,就是正常处理,继续往下游Bolt发。Stateful Bolt则需要把状态存起来,把Checkpoint发送给Topology Master,直到Ending boltTM发送Checkpoint barrier。当所有的Ending bolt都做完Checkpoint后,就会将状态存在Hdfs/hbase中,再通知Spout发送下一个Batch。

5f4b63ca7ac1cb696a554bdea24a2f4a98e3c7d4 

实际上,每一个batch的处理和发送是可以并行的,只是TM本身的Checkpoint是串行的,这样就可以很好的提高性能。比如中间有一个Batch处理失败了,TM会得知,此时就会做Rollback,向Spout发送Rollback barrier,从Hdfs/hbase中找出最近完成的Checkpoint,删除历史无用的Checkpoint,Spout会从状态中重新恢复Offset,Stateless Bolt会继续处理,Stateful Bolt会把Checkpoint所对应的状态从Hdfs/hbase中拉出来恢复,再根据数据计算。

其他特性

其他的特性包括自定义调度、动态调整日志级别自定义日志(外部应用可以很方便做日志采集、基于日志的监控报警)、用户自定义metrics(根据业务日志做监控报警)、优雅shutdown(把所有的消息处理完之后再shutdown)、动态扩容、更新配置

新的窗口机制

Storm的Window有很多问题,所有的数据需要统一处理,在工业级的产品中不可行。重构的窗口机制不会在内存憋每个窗口的数据,只需要存每个窗口的处理结果。重构的窗口机制,支持Processing timeIngestion timeEvent timeWatermark (late element)Window early fire

JStorm Future

Apache Beam提供了一次编写、多个不同引擎到处运行的特性。JStorm也会适配Beam,做Apache Beam JStorm runnerJStorm SQL需要进行重构和优化。将来计划在Jstorm上封装一些算子、整合框架,使其易于开发、调试,性能更加优化。

相关文章
|
26天前
|
机器学习/深度学习 安全 大数据
揭秘!企业级大模型如何安全高效私有化部署?全面解析最佳实践,助你打造智能业务新引擎!
【10月更文挑战第24天】本文详细探讨了企业级大模型私有化部署的最佳实践,涵盖数据隐私与安全、定制化配置、部署流程、性能优化及安全措施。通过私有化部署,企业能够完全控制数据,确保敏感信息的安全,同时根据自身需求进行优化,提升计算性能和处理效率。示例代码展示了如何利用Python和TensorFlow进行文本分类任务的模型训练。
73 6
|
2月前
|
存储 Cloud Native 关系型数据库
Ganos实时热力聚合查询能力解析与最佳实践
Ganos是由阿里云数据库产品事业部与飞天实验室共同研发的新一代云原生位置智能引擎,集成于PolarDB-PG、Lindorm、AnalyticDB-PG和RDS-PG等核心产品中。Ganos拥有十大核心引擎,涵盖几何、栅格、轨迹等多种数据处理能力,实现了多模多态数据的一体化存储、查询与分析。本文重点介绍了Ganos的热力瓦片(HMT)技术,通过实时热力聚合查询与动态输出热力瓦片,无需预处理即可实现大规模数据秒级聚合与渲染,适用于交通、城市管理、共享出行等多个领域。HMT相比传统网格聚合技术具有高效、易用的优势,并已在多个真实场景中验证其卓越性能。
55 0
|
17天前
|
自然语言处理 并行计算 数据可视化
免费开源法律文档比对工具:技术解析与应用
这款免费开源的法律文档比对工具,利用先进的文本分析和自然语言处理技术,实现高效、精准的文档比对。核心功能包括文本差异检测、多格式支持、语义分析、批量处理及用户友好的可视化界面,广泛适用于法律行业的各类场景。
|
20天前
|
PHP 开发者 容器
PHP命名空间深度解析与最佳实践####
本文深入探讨了PHP中命名空间(namespace)的机制、应用场景及最佳实践,旨在帮助开发者有效避免命名冲突,提升代码的组织性和可维护性。通过实例讲解,本文将引导您理解如何在实际项目中灵活运用命名空间,以及如何遵循业界公认的最佳实践来优化您的PHP代码结构。 ####
|
19天前
|
PHP 开发者
PHP 7新特性深度解析及其最佳实践
【10月更文挑战第31天】本文将深入探讨PHP 7带来的革新,从性能提升到语法改进,再到错误处理机制的变革。我们将通过实际代码示例,展示如何高效利用这些新特性来编写更加健壮和高效的PHP应用。无论你是PHP新手还是资深开发者,这篇文章都将为你打开一扇窗,让你看到PHP 7的强大之处。
|
28天前
|
监控 数据挖掘 OLAP
深入解析:AnalyticDB中的高级查询优化与性能调优
【10月更文挑战第22天】 AnalyticDB(ADB)是阿里云推出的一款实时OLAP数据库服务,它能够处理大规模的数据分析任务,提供亚秒级的查询响应时间。对于已经熟悉AnalyticDB基本操作的用户来说,如何通过查询优化和性能调优来提高数据处理效率,是进一步提升系统性能的关键。本文将从个人的角度出发,结合实际经验,深入探讨AnalyticDB中的高级查询优化与性能调优技巧。
71 4
|
27天前
|
监控 安全 Serverless
"揭秘D2终端大会热点技术:Serverless架构最佳实践全解析,让你的开发效率翻倍,迈向技术新高峰!"
【10月更文挑战第23天】D2终端大会汇聚了众多前沿技术,其中Serverless架构备受瞩目。它让开发者无需关注服务器管理,专注于业务逻辑,提高开发效率。本文介绍了选择合适平台、设计合理函数架构、优化性能及安全监控的最佳实践,助力开发者充分挖掘Serverless潜力,推动技术发展。
58 1
|
1月前
|
监控 安全 Java
构建高效后端服务:微服务架构深度解析与最佳实践###
【10月更文挑战第19天】 在数字化转型加速的今天,企业对后端服务的响应速度、可扩展性和灵活性提出了更高要求。本文探讨了微服务架构作为解决方案,通过分析传统单体架构面临的挑战,深入剖析微服务的核心优势、关键组件及设计原则。我们将从实际案例入手,揭示成功实施微服务的策略与常见陷阱,为开发者和企业提供可操作的指导建议。本文目的是帮助读者理解如何利用微服务架构提升后端服务的整体效能,实现业务快速迭代与创新。 ###
63 2
|
2月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
432 37
|
1月前
|
存储 缓存 监控
深入解析:Elasticsearch集群性能调优策略与最佳实践
【10月更文挑战第8天】Elasticsearch 是一个分布式的、基于 RESTful 风格的搜索和数据分析引擎,它能够快速地存储、搜索和分析大量数据。随着企业对实时数据处理需求的增长,Elasticsearch 被广泛应用于日志分析、全文搜索、安全信息和事件管理(SIEM)等领域。然而,为了确保 Elasticsearch 集群能够高效运行并满足业务需求,需要进行一系列的性能调优工作。
100 3
下一篇
无影云桌面