Storm初始化时抛出NotSerializableException

博客指出启动topo时抛出异常,在storm、bolt和spout中不能含非静态且对象创建时初始化的字段。给出解决方案,bolt在pepare方法中初始化,spout可重构或冒险序列化,并提出实行序列化有何危险的疑问。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

启动topo抛出如下异常:

Exception in thread "main" java.lang.IllegalStateException: Spout 'DetrUpdateEvent' contains a non-serializable field of type com.gdl.trolley.stormclient.TrolleySpout$StormMessageListner, which was instantiated prior to topology creation. com.gdl.trolley.stormclient.TrolleySpout$StormMessageListner should be instantiated within the prepare method of 'DetrUpdateEvent at the earliest.
    at backtype.storm.topology.TopologyBuilder.createTopology(TopologyBuilder.java:138)
    at com.gdl.gdl.gdlpsr.processor.detrupdate.DetrupdateTopology.main(DetrupdateTopology.java:42)
Caused by: java.lang.RuntimeException: java.io.NotSerializableException: com.gdl.trolley.stormclient.TrolleySpout$StormMessageListner
    at backtype.storm.utils.Utils.javaSerialize(Utils.java:196)
    at backtype.storm.topology.TopologyBuilder.createTopology(TopologyBuilder.java:135)
    ... 1 more
Caused by: java.io.NotSerializableException: com.gdl.trolley.stormclient.TrolleySpout$StormMessageListner
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1184)
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548)
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1509)
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432)
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178)
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:348)
    at backtype.storm.utils.Utils.javaSerialize(Utils.java:192)
    ... 2 more

在storm和bolt和spout中不能包含非静态且在对象创建时初始化的字段。如下面代码时不被允许的。

public class TrolleySpout extends KafkaSpout {
    private static KafkaSpoutConfig.Builder builder = KafkaSpoutConfig.builderStringBytes(UpdateConfig.getInstance().getBrokerHosts()
            , UpdateConfig.getInstance().getAppid());
    private StormMessageListner stormMessageListner = new StormMessageListner();

解决方案:对于bolt,在pepare方法中完成初始化。对于spout,要么重构,要么冒险进行序列化。
实行序列化有什么危险呢?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值