本篇内容介绍了“storm实时排序TopN怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
阅读背景:1 您需要了解TOP 使用的场景
2 您需要了解当前的TOPN 处理,和定时区间处理的区别
看代码说话
packagecom.cc.storm;importcom.cc.storm.bolt.MergeBolt;importcom.cc.storm.bolt.RankBolt;importcom.cc.storm.bolt.RollingAllCountBolt;importcom.cc.storm.bolt.RollingCountBolt;importcom.cc.storm.spout.RandomEmitSpout;importcom.cc.storm.spout.RedisPubSubSpout;importbacktype.storm.Config;importbacktype.storm.LocalCluster;importbacktype.storm.StormSubmitter;importbacktype.storm.generated.AlreadyAliveException;importbacktype.storm.generated.InvalidTopologyException;importbacktype.storm.topology.TopologyBuilder;importbacktype.storm.tuple.Fields;/***ToPN是一种常见模式,是对流式数据进行“StreamingtopN”的计算:*比如要计算的是最近一段时间内的热门话题,热门点击图片,热门商品浏览,热门商品购买**既然敢要实时的处理,【】【】【】【】【】[]【】【】【】【】【】[]【】【】【】【】【】[]**@authorYinShuai*/publicclassTOP10{publicstaticvoidmain(String[]args)throwsAlreadyAliveException,InvalidTopologyException,InterruptedException{finalintTOP_N=10;finalinttime=1;TopologyBuilderbuilder=newTopologyBuilder();builder.setSpout("$datasource$",newRandomEmitSpout(),1);builder.setBolt("$count$",newRollingCountBolt(3,time),1).fieldsGrouping("$datasource$",newFields("merchandiseIDS"));builder.setBolt("$rank$",newRankBolt(TOP_N),2).fieldsGrouping("$count$",newFields("merchandiseID"));builder.setBolt("$merge$",newMergeBolt(TOP_N)).globalGrouping("$rank$");Configconf=newConfig();conf.setDebug(false);conf.setNumWorkers(2);conf.setMaxSpoutPending(5000);LocalClustercluster=newLocalCluster();cluster.submitTopology("Getting-Started-Toplogie",conf,builder.createTopology());Thread.sleep(5000);}}
整个处理的流程如图:
“storm实时排序TopN怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注恰卡编程网网站,小编将为大家输出更多高质量的实用文章!
Storm怎么写一个爬虫
Storm怎么写一个爬虫这篇文章主要讲解了“Storm怎么写一个爬...
怎么用Storm IPResolutionBolt写爬虫
怎么用StormIPResolutionBolt写爬虫本篇内容介...
Storm RandomURLSpout怎么使用
StormRandomURLSpout怎么使用本篇内容介绍了“S...
如何用Storm来写一个Crawler的工具
Storm开发细节是什么
Storm的Acker机制是什么
Storm的Acker机制是什么这篇文章主要讲解了“Storm的A...
storm drpc怎么定义
stormdrpc怎么定义本篇内容介绍了“stormdrpc怎...
storm使用要注意哪些点
storm使用要注意哪些点这篇文章主要讲解了“storm使用要注意...
storm topology优化思路是什么
stormtopology优化思路是什么本篇内容主要讲解“sto...
Storm的Grouping有哪些
Storm的Grouping有哪些这篇文章主要介绍“Storm的G...
用户名
密码
记住登录状态 忘记密码?
邮箱
确认密码
我已阅读并同意 用户协议