近期,在一个自动化运维平台中,通过前台页面修改监控采数频率,结果平台监控不再刷新,观察后台日志,发现
一直刷数据类型转换异常的错误。
开发语言:JAVA
JDK版本:java version "1.8.0_211"
MongoDB版本:3.2.16
后台日志报错如下:
根据报错提示的java类定位到具体的报错代码如下:
由此,可知引起异常的代码是:
long intervalDynamic = conf.getLong("interval_dynamic");
观察MongoDB内对应的数据:
到此,问题可能出在:程序在对mongodb数据库里的interval_dynamic从Object转换成Long时出现数据类型转换异常。
经沟通监控平台的初始化是后台脚本初始化,mongdb初始化的时候是数字类型,监控取出的时候是bson,按key取值为
Object类型,不能直接强制转换成Long,可能跟JDK版本有关。
经调试,将数据转换做如下调整,程序恢复正常运行:
总结:JAVA读取MongoDB数据为二进制的Bson,JAVA按字段获取到的数据为Object数据,在转换为Long之前,先过
渡转换为String类型,再使用Long.valueOf(String)方法将String数据转换为Long类型。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。