一开始使用的是jboss7.0,因为安全要求,需要升级到Jboss7.3,做好测试环境后,开始发现jboss会莫名其妙退出。仔细检查后发现,居然是段错误。
我一个java程序员,处理段错误是没有经验的。依据网上的内容,先查看hs_err_pidxxx.log文件
仔细一看,居然是Jacob报错了,心想,不该啊,只是升级个jboss,关它什么事情。
出了问题就要解决,最初,怀疑是没有做多线程访问安全导致,于是,先改为单例模式,使用synchronized来修饰关键代码。进行测试,依旧会挂掉,依旧是段错误。
摸不着头脑,各种查资料,看到微软官网有说,com口多线程调用是会有不可预期的异常,心里都生出来放弃的念头了。准备改用其他方案。最后,还是决定死马当活马医,改一版。
然后,居然没有出错了,安全运行了两周。以前最多三天就会挂掉。
具体修改方式,采用单例模式,每次调用时,初始化新的activeXCompent对象,在使用完毕后,调用safeRelease方法,依次释放所有Jacob对象,并在最后一步,调用comThread.Release()方法释放对象。
总结:comThread的释放,需要手工完成,以阻止jvm的垃圾回收函数调用Release()方法,导致多次释放同一对象,造成段错误。