您的位置:首页 > 编程语言 > Java开发

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

2014-08-25 14:27 591 查看
在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");
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐