在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
随着数据体积的越来越大,实时处理成为了许多机构需要面对的首要挑战,而Storm让大数据分析变得轻松加愉快。今天,小编和大家分享大数据面试题之Storm实时看板案例。
1、需求分析
平台在活动促销日(例如双 11)要求实时展示当日的一些销售信息我们从三个维度去统计计算:
平台运维角度统计指标: 平台总销售额、平台下单人数、平台商品销售数量。
商品销售角度统计指标: 每个商品总销售额、每个商品购买人数、每个商品销售数量。
店铺销售角度统计指标: 每个店铺总销售额、每个店铺购买人数、每个店铺销售数量。
2、确定数据源
数据源:订单系统与支付系统产生的数据。
3、确定采集方案
订单系统和支付系统产生的数据 通过 ActiveMQ 到 kafka 中,Storm 集成kafka 获取数据。(注:为什么用 ActiveMQ?一方面,电商业务系统当中需要用到事务支持,只能用比较严谨的 jms 系统来实现,所以考虑到用 ActiveMQ。另一方面,kafka 直接读取数据库,会影响数据库速度。所以订单系统的数据通过 ActiveMQ 这个中间件来落地到数据库,kafka从ActiveMQ 中间件中取数据,就可以避免直接读数据库的问题。)
4、确定存储
我们将 Storm 处理后的数据,通过 Redis 来累加计数并存储在 Redis 中。
5、数据计算
编写 Storm 代码:Storm 与 kafka 整合来获取到数据,将每一条数据信息,利用 Redis 中 incrBy 这个命令来累加计数并存储在 Redis 中。
6、展现
可以写一个定时器,定时的去 Redis 中获取结果数据,展示到 web 界面上。
7、storm 日志监控告警系统
8、需求分析
实现项目中日志监控的功能,需要做到日志监控实时告警,例如系统中出现任何异常,触发任何的告警规则,都可以实时通过短信或者邮件告知相关系统负责人。
9、确定数据源
每个业务系统(如: 订单系统,商品管理系统,用户系统)产生的日志信息。
10、确定采集方案
将日志数据 通过 flume 采集到 kafka 中,Storm 集成 kafka 获取数据。
11、确定存储
将触发告警规则的数据,存储在 MySQL 数据库中。
12、数据计算
·通过自定义flume 拦截器,给不同系统产生的日志数据前加上一个appId 来做唯一标识(不同系统对应的告警规则和负责人不同,所以这里要加一个唯一标识方便我们查找对应的规则和负责人)。
·Storm 代码编写步骤:
(1)、获取 kafka 中的数据。
(2)、设置定时器,定时读取在 MySQL 数据库中的告警规则(数据库中的告警规则我们可以随时去修改,所以要采用定时器去读取,保证拿到是最新的规则)。
(3)、将获取到的数据,与告警规则进行匹配,得到匹配成功的告警数据信息。
(4)、将告警信息 以邮件,或者短信 方式发送给对应的负责人(对应人的信息,从 MySQL 数据库中获取)。
(5)、最后将警告信息存储到我们的 MySQL 数据库中(方便以后查询异常记录)。
以上就是小编整理的大数据面试题之Storm实时看板案例,大家都弄明白了吗?
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
如何搭建hadoop平台?详细步骤讲解
如何搭建hadoop平台?本文将详细讲解以下步骤:虚拟机及系统安装、在虚拟机中配置JAVA环境、修改hosts、修改hostname vim 、配置ssh、压缩包解压、修改hadoop配置文件、修改HBase配置、修改HBase配置、修改hive配置、修改sqoop配置、修改zookeeper配置等等,手把手指导大家搭建hadoop平台。
9563
2019-08-08 15:46:19
Spark运行架构及其特点讲解
Spark应用程序以进程集合为单位在分布式集群上运行,通过driver程序的main方法创建的SparkContext对象与集群交互。本文主要内容有Spark运行架构的流程讲解和Spark运行架构的特点分析,感兴趣的小伙伴就赶紧看下去吧!
7779
2019-08-20 19:22:54
常见的数据建模工具有哪些?
常见的数据建模工具有哪些?企业选择数据建模工具时,需要找到现在和将来最有可能使用的功能。企业并不需要拥有所有功能的工具,但可以尝试采用一些不同的平台找出可以满足其需求并提高生产率的工具。可以集成来自不同系统的数据,使用免费的数据建模工具来组织大数据,以便更轻松地访问信息。通过寻找复杂概念的图形表示来了解企业的业务。
10760
2020-03-23 17:05:45
大数据开发工程师需要学习哪些知识点?
大数据开发工程师需要学习哪些知识点?大数据程序员需要有坚实的大数据技术理论基础、了解数据平台、掌握数据存储 HDFS、、日志解析及计算 MR、数据获取和预处理 Flume、结构化查询 Hive、数据获取和预处理 Sqoop、大数据调度框架Azkaban、Scala编程基础等相关知识。
6940
2020-09-03 14:13:34
吐血整理的大数据学习资源大全
大量学习资源,内容系统且全面,各大网站、相关书籍、公众号等。
3779
2022-08-05 18:32:12
热门文章
- 前端是什么
- 前端开发的工作职责
- 前端开发需要会什么?先掌握这三大核心关键技术
- 前端开发的工作方向有哪些?
- 简历加分-4步写出HR想要的简历
- 程序员如何突击面试?两大招带你拿下面试官
- 程序员面试技巧
- 架构师的厉害之处竟然是这……
- 架构师书籍推荐
- 懂了这些,才能成为架构师 查看更多
扫描二维码,了解更多信息
