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

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 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上封装一些算子、整合框架,使其易于开发、调试,性能更加优化。

相关文章
|
3月前
|
机器学习/深度学习 安全 大数据
揭秘!企业级大模型如何安全高效私有化部署?全面解析最佳实践,助你打造智能业务新引擎!
【10月更文挑战第24天】本文详细探讨了企业级大模型私有化部署的最佳实践,涵盖数据隐私与安全、定制化配置、部署流程、性能优化及安全措施。通过私有化部署,企业能够完全控制数据,确保敏感信息的安全,同时根据自身需求进行优化,提升计算性能和处理效率。示例代码展示了如何利用Python和TensorFlow进行文本分类任务的模型训练。
186 6
|
18天前
|
存储 运维 资源调度
阿里云服务器经济型e实例解析:性能、稳定性与兼顾成本
阿里云经济型e云服务器以其高性价比、稳定可靠的性能以及灵活多样的配置选项,成为了众多企业在搭建官网时的首选。那么,阿里云经济型e云服务器究竟怎么样?它是否能够满足企业官网的搭建需求?本文将从性能表现、稳定性与可靠性、成本考虑等多个方面对阿里云经济型e云服务器进行深入剖析,以供大家参考选择。
|
21天前
|
缓存 算法 Oracle
深度干货 如何兼顾性能与可靠性?一文解析YashanDB主备高可用技术
数据库高可用(High Availability,HA)是指在系统遇到故障或异常情况时,能够自动快速地恢复并保持服务可用性的能力。如果数据库只有一个实例,该实例所在的服务器一旦发生故障,那就很难在短时间内恢复服务。长时间的服务中断会造成很大的损失,因此数据库高可用一般通过多实例副本冗余实现,如果一个实例发生故障,则可以将业务转移到另一个实例,快速恢复服务。
深度干货  如何兼顾性能与可靠性?一文解析YashanDB主备高可用技术
|
2月前
|
人工智能 搜索推荐 API
Cobalt:开源的流媒体下载工具,支持解析和下载全平台的视频、音频和图片,支持多种视频质量和格式,自动提取视频字幕
cobalt 是一款开源的流媒体下载工具,支持全平台视频、音频和图片下载,提供纯净、简洁无广告的体验
305 9
Cobalt:开源的流媒体下载工具,支持解析和下载全平台的视频、音频和图片,支持多种视频质量和格式,自动提取视频字幕
|
2月前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
169 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
22天前
|
存储 人工智能 NoSQL
Tablestore深度解析:面向AI场景的结构化数据存储最佳实践
《Tablestore深度解析:面向AI场景的结构化数据存储最佳实践》由阿里云专家团队分享,涵盖Tablestore十年发展历程、AI时代多模态数据存储需求、VCU模式优化、向量检索发布及客户最佳实践等内容。Tablestore支持大规模在线数据存储,提供高性价比、高性能和高可用性,特别针对AI场景进行优化,满足结构化与非结构化数据的统一存储和高效检索需求。通过多元化索引和Serverless弹性VCU模式,助力企业实现低成本、灵活扩展的数据管理方案。
59 12
|
3月前
|
存储 缓存 监控
后端开发中的缓存机制:深度解析与最佳实践####
本文深入探讨了后端开发中不可或缺的一环——缓存机制,旨在为读者提供一份详尽的指南,涵盖缓存的基本原理、常见类型(如内存缓存、磁盘缓存、分布式缓存等)、主流技术选型(Redis、Memcached、Ehcache等),以及在实际项目中如何根据业务需求设计并实施高效的缓存策略。不同于常规摘要的概述性质,本摘要直接点明文章将围绕“深度解析”与“最佳实践”两大核心展开,既适合初学者构建基础认知框架,也为有经验的开发者提供优化建议与实战技巧。 ####
|
2月前
|
监控 数据管理 测试技术
API接口自动化测试深度解析与最佳实践指南
本文详细介绍了API接口自动化测试的重要性、核心概念及实施步骤,强调了从明确测试目标、选择合适工具、编写高质量测试用例到构建稳定测试环境、执行自动化测试、分析测试结果、回归测试及集成CI/CD流程的全过程,旨在为开发者提供一套全面的技术指南,确保API的高质量与稳定性。
|
2月前
|
PHP 开发者 容器
PHP命名空间深度解析及其最佳实践####
本文深入探讨了PHP中引入命名空间的重要性与实用性,通过实例讲解了如何定义、使用及别名化命名空间,旨在帮助开发者有效避免代码冲突,提升项目的模块化与可维护性。同时,文章还涉及了PHP-FIG标准,引导读者遵循最佳实践,优化代码结构,促进团队协作效率。 ####
39 1
|
2月前
|
Java 数据库连接 开发者
Java中的异常处理机制:深入解析与最佳实践####
本文旨在为Java开发者提供一份关于异常处理机制的全面指南,从基础概念到高级技巧,涵盖try-catch结构、自定义异常、异常链分析以及最佳实践策略。不同于传统的摘要概述,本文将以一个实际项目案例为线索,逐步揭示如何高效地管理运行时错误,提升代码的健壮性和可维护性。通过对比常见误区与优化方案,读者将获得编写更加健壮Java应用程序的实用知识。 --- ####

推荐镜像

更多