jacob.dll already loaded in another classloader
来源:互联网 发布:精益算命软件 编辑:程序博客网 时间:2024/06/07 08:41
使用jacob时发生UnsatisfiedLinkError的问题 [原]
问题描述:
我在一个Web应用中(server是resin-ee-2.1.4)使用jacob完成word文档自动转换成pdf文档的功能(详见我另一篇日志),为了保证web应用的稳定性,我提供了resin每晚自动重启的机制,方法是利用定时servlet修改resin.conf文件。但是当web应用重启后,jacob会报以下错误;
Native Library C:/WINNT/system32/jacob.dll already loaded in another classloader
java.lang.UnsatisfiedLinkError: Native Library C:/WINNT/system32/jacob.dll already loaded in another classloader
at java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1437)
at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1397)
at java.lang.Runtime.loadLibrary0(Runtime.java:788)
at java.lang.System.loadLibrary(System.java:832)
at com.jacob.com.Variant.<clinit>(Variant.java)
……
然后转pdf的功能会彻底失效,直到手工重启resin服务。
问题分析:
经过查看jacob源代码发现在Variant类中有一个静态方法:
static {
System.loadLibrary("jacob";
}
而UnsatisfiedLinkError错误表明jacob.dll已经被JVM的ClassLoader load了。通过查阅资料发现Web Server的自动重启机制是产生这一问题的根源。当Resin重启包含jacob的这个Web应用时,会因为Variant类的语句而自动执行jacob的加载。但重启Web应用并不是重启整个resin(即:上一次启动的JVM仍然存在),也就是说jacob已经被加载过了,因此系统将抛出UnsatisfiedLinkError错误。而当我们手工重启resin时,则会将上一次启动的JVM关闭并重新启动,这时会正常加载jacob。
问题解决:
Java API表明:JVM只允许一个默认的ClassLoader来load native library,同时并不提供专门的API来unload一个loaded native library,因此无法在我们的重启Web应用的代码中来手工清除已经load的jacob。为此我们必须保证在重启Web应用时不再重复加载jacob,具体方法是:将jacob.jar包放到Web Server的公共lib文件夹中(如:.../resin-ee-2.1.4/lib/),而不是Web应用的lib中(如:.../WEB-INF/lib/)。经过测试,自动重启Web应用后,问题不再出现。
后记:
虽然问题已解决,但总感觉有些不爽,毕竟没有从根源上解决。还希望看到此篇日志的网友继续研究,如果能找出unload loaded native library的方法,希望贴上来大家共享。
- jacob.dll already loaded in another classloader
- jacob.dll already loaded in another classloader
- jacob.dll already loaded in another classloader
- jacob.dll already loaded in another classloader
- jacob 多个web项目报错 jacob-1.14.3-x64.dll already loaded in another classloader jacob
- 解决XXX.dll already loaded in another classloader问题
- 解决"java.lang.UnsatisfiedLinkError: Native Library xxx.dll already loaded in another classloader"问题
- 解决"java.lang.UnsatisfiedLinkError: Native Library xxx.dll already loaded in another classloader"问题
- java.lang.UnsatisfiedLinkError: Native Library * already loaded in another classloader
- java中tomcat重启时加载动态库XXX.dll报错“java.lang.UnsatisfiedLinkError: already loaded in another classloader”
- Native Library xxx.so already loaded in another classloader 的解决方法
- Native Library Jawin already loaded in another classloader解决办法[Weblogic10.3]
- Native Library /usr/lib/libJMagick.so already loaded in another classloader
- 解决 java.lang.UnsatisfiedLinkError: Native Library XX.dll already loaded in another
- Unable to load sqlite_jni: java.lang.UnsatisfiedLinkError: Native Library D:/resin/bin/sqlite_jni.dll already loaded in another
- jsp连接Oracle错误:ocijdbc8.dll already loaded 解决方法
- Module 'mysql' already loaded in Unknown on line 0解决方法
- Another unnamed CacheManager already exists in the same VM
- 珍惜自己的时间!
- Java: 位操作
- 总算在csdn安家了…
- 《Java与模式》学习笔记(8)——序列键生成器与单例及多例模式
- 数据结构 图 最短路径
- jacob.dll already loaded in another classloader
- .Net PetShop 4.0的缓存处理
- Java: Assertions
- 天道筹勤,今天给自己D-bus进行基本接口扫盲
- GPSReceiver
- 应用程序中的服务器错误。 配置错误
- 关于JDBC和JDBC-ODBC连接数据库
- [行业]个人软件(PC软件)的N大领域&Linux PC发展之我见
- C#实现IP地址控件