storm中使用log出现java.lang.RuntimeException: java.io.NotSerializableException: java.util.logging.Logger

在storm中,想自己去写日志,使用的是如下方法:

 Logger loger =Logger.getLogger("test.Test");
	        FileHandler fh = new FileHandler("c:/test.log",true);//方法返回日志文件存放的路径
	        loger.addHandler(fh);
	        loger.setLevel(Level.ALL);
	        SimpleFormatter sf = new SimpleFormatter();
	        fh.setFormatter(sf);
	        loger.log(Level.INFO, "这是一个消息");
	        loger.log(Level.WARNING, "这是一个警告");
	        loger.log(Level.SEVERE, "这是一个服务器消息");
	        loger.info( "---> fail");

在bolt中,直接进行loger的声明:

Logger loger =Logger.getLogger("test.Test");

接触就出现了如下的异常

java.lang.RuntimeException: java.io.NotSerializableException: java.util.logging.Logger
        at backtype.storm.utils.Utils.serialize(Utils.java:57) ~[storm-core-0.9.0.1.jar:na]
        at backtype.storm.topology.TopologyBuilder.createTopology(TopologyBuilder.java:89) ~[storm-core-0.9.0.1.jar:na]
        at lotuseed.experiment.StormQLTopology.main(StormQLTopology.java:37) ~[experiment.jar:na]
Caused by: java.io.NotSerializableException: java.util.logging.Logger
        at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1183) ~[na:1.7.0_51]
        at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1547) ~[na:1.7.0_51]
        at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1508) ~[na:1.7.0_51]
        at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1431) ~[na:1.7.0_51]
        at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1177) ~[na:1.7.0_51]
        at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:347) ~[na:1.7.0_51]
        at backtype.storm.utils.Utils.serialize(Utils.java:53) ~[storm-core-0.9.0.1.jar:na]
        ... 2 common frames omitted


解决方法是:要将这个声明转换为静态的声明:

private static Logger loger =Logger.getLogger("test.Test");



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值