首页 > 代码库 > Storm问题——组件带参数构造函数未被调用,抛出NullpointerException
Storm问题——组件带参数构造函数未被调用,抛出NullpointerException
问题描述
不知道大家有没有遇到过这个问题,我实现了BaseRichBolt,重载一个带参数的构造函数,new这个组件时传入一个参数作为该组件的成员变量,然后在declareOutputFields方法中调用该变量,local模式运行正常,分布式模式运行就抛NPE。后来过了半小时,再提交,又OK了。(PS:其间检查了很多遍代码,没有传入NULL变量)
我在开发trident程序时,继承mapState时也出现了这个问题
可能原因
1、跟storm本身的序列化机制有关系,storm本身对组件进行序列化和反序列化时,提供一个默认的无参构造函数,至于为什么会提供这个,请看可能原因2
2、猜想在分布式环境,storm要根据集群topology的工作来维护各个topology之间的状态以及一些细节state之类的,突然有些时候state变化,就导致了上面的问题
这两个可能原因目前还是自己的YY,没有找到具体原因,后续继续研究源码,找到再补上。
Storm问题——组件带参数构造函数未被调用,抛出NullpointerException
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。