MongoDB Java开发从Mongo读取对象值转长异常引起的数据类型转换异常

  

,,近期,在一个自动化运维平台中,通过前台页面修改监控采数频率,结果平台监控不再刷新,观察后台日志,发现   

  

一直刷数据类型转换异常的错误。

  

,,,开发语言:JAVA

  

,,JDK版本:java版本“1.8.0_211"

  

,,MongoDB版本:3.2.16

  

,,后台日志报错如下:

  

   MongoDB Java开发从Mongo读取对象值转长异常引起的数据类型转换异常

  

,,根据报错提示的java类定位到具体的报错代码如下:

  

   MongoDB Java开发从Mongo读取对象值转长异常引起的数据类型转换异常

  

,,由此,可知引起异常的代码是:

  

长intervalDynamic=conf.getLong (“interval_dynamic");

  

,,观察MongoDB内对应的数据:   

  

   MongoDB Java开发从Mongo读取对象值转长异常引起的数据类型转换异常

  

,,到此,问题可能出在:程序在对mongodb数据库里的interval_dynamic从对象转换成长时出现数据类型转换异常。

  

经沟通监控平台的初始化是后台脚本初始化,mongdb初始化的时候是数字类型,监控取出的时候是bson,按关键取值为

  

对象类型,不能直接强制转换成长,可能跟JDK版本有关。

  

,,经调试,将数据转换做如下调整,程序恢复正常运行:

  

   MongoDB Java开发从Mongo读取对象值转长异常引起的数据类型转换异常

  

,,总结:JAVA读取MongoDB数据为二进制的Bson, JAVA按字段获取到的数据为对象的数据,在转换为长之前,先过

  

渡转换为字符串类型,再使用Long.valueOf (String)方法将字符串数据转换为长类型。

MongoDB Java开发从Mongo读取对象值转长异常引起的数据类型转换异常