错误学习:Java + OSGi

最近,我致力于在OSGi环境中使Apache Hive工作。 虽然没有被证明是小菜一碟(软件对吗?。。为什么我不感到惊讶? :) ),它引导我解决了各种Java和OSGi错误。 在这里,我列出了其中一些让我有些吃力的东西(没有双关语),所以我想为了自己的满意而在它们上面写一个博客。

java.lang.VerifyError

在初始化OSGi服务组件之一的过程中,我感到很讨厌。 由于违规捆绑软件处于活动状态,因此无法立即识别出罪魁祸首。 从表面上看,一切看起来都不错,除了应该在捆绑软件中存在的服务组件初始化期间启动的Hive服务器未启动并正在运行的事实。 OSGi控制台中快速显示“ ls”,表明服务组件处于“不满意”状态。 最后,一个“ comp”显示了根本原因,即VerifyError。

如果类的运行时依赖项与编译时使用的依赖项不同,则可能会发生VerifyError。 例如,如果方法签名在依赖关系之间更改,则将导致此错误。 在已接受的答案的[1]中对此进行了很好的解释。 事实证明,在两个捆绑包中公开了一个软件包的稍有不同的版本,导致Hive捆绑包在编译环境中的版本上选择了不同的版本。 正确的OSGi版本控制是解决方案。

java.lang.IncompatibleClassChangeError

在系统中存在两个软件包的类似情况下,也会出现此错误。 正如[2]清楚地解释的那样,在我的案例中,这样做的原因是在有冲突的软件包版本之间将接口更改为抽象类。 再次,版本控制节省了一天。

java.lang.LinkageError:xxxx中违反加载程序约束–等等……

现在,这似乎是一个著名的错误,特别是在OSGi环境中。 根本原因似乎是由不同的ClassLoader以某种方式进入的两个类加载的。 例如,说A类对象接受B类对象作为方法参数。 B类由ClassLoader-A加载,该类加载器也加载A类。但是,在方法调用时,由ClassLoader-B加载的B类对象如何作为参数传递给已加载的A类对象通过ClassLoader-A。 现在,结果将是一个很大的LinkageError,并带有非常冗长的错误消息。

OSGi中基于图的类加载结构使其特别有利于此类错误。 在我的案例中,罪魁祸首是一个包装,该包装已被复制到两个不同的包中,并且该包中的一个特定类由每个包的单独的ClassLoader加载,并通过方法调用期间系统中存在的第三个包来联系。 因此,这是在OSGi中不遵循“导入导出内容”的最佳做法[3]的情况。 这样做将有助于减少重复的包在捆绑包中的暴露,并有助于为给定的包维护一致的类空间。 因此,这就是这种情况下的解决方案。

包使用冲突:导入包:yyy; 版本=“ xxx”

在锻炼过程中,我经常将这种不便之处丢在脸上。 在SpringSource上有两个关于此问题的出色文章[4],[5],它们提供了很多帮助。 但是,让我总结一下我在这个问题上的学习。 简单来说,如果捆绑包通过直接导入并通过使用约束暴露给同一软件包的两个版本,则会出现此错误。 该图最能说明这种情况。

捆绑软件A直接导入org.foo版本1.0.0。 但是,它也从捆绑软件B导入捆绑软件org.bar。但是事实证明,软件包org.bar也使用org.foo软件包,尽管它是与捆绑软件A导入的版本不同的版本(2.0.0)。直接连接到org.foo的1.0.0版本,并且由于使用org.foo的2.0.0版本的org.bar的导入而暴露于org.foo的2.0.0版本。 现在,由于无法将捆绑包连接到同一软件包的不同版本,因此使用冲突将引起冒犯的导入org.bar作为根本原因。 (例如:程序包使用冲突:导入程序包:org.bar;版本=“ 0.0.0?”)。 解决方案是更改捆绑软件A或捆绑软件B中的org.bar软件包导入版本,以使两者都指向相同的软件包版本。 尼尔·巴特利特(Neil Bartlett)撰写的另一篇很棒的博客可以在[6]中找到。

java.lang.UnsatisfiedLinkError

我的一个工作朋友在尝试将另一个第三方库纳入我们的OSGi环境时遇到了这个问题。 JavaDocs继续说这变得“如果Java虚拟机无法找到声明为native的方法的适当的本地语言定义,则会抛出此错误”。 有问题的库是一个Linux .so(动态链接库)文件,在运行时捆绑ClassLoader时看不到该文件。 通过将库资源直接包含在捆绑软件ClassLoader中,我们能够使其工作。 之前在TCCL(线程上下文类加载器)上设置此资源的尝试失败了,这使我们意识到TCCL通常不是捆绑软件类加载器。 在Equinox OSGi环境下可以很好地阅读TCCL,请参见[7]。

[1] http://stackoverflow.com/questions/100107/reasons-of-getting-a-java-lang-verifyerror
[2] http://stackoverflow.com/questions/1980452/what-c​​auses-java-lang-incompatibleclasschangeerror
[3] http://blog.osgi.org/2007/04/importance-of-exporting-nd-importing.html [4] http://blog.springsource.org/2008/10/20/understanding-the-osgi-uses-directive/ [5] http://blog.springsource.org/2008/11/22/diagnosing-osgi-uses-conflicts/ [6] http://njbartlett.name/2011/02/09/uses-constraints.html [7] http://wiki.eclipse.org/Context Loader_Enhancements

参考: 错误学习:来自Source Open博客的JCG合作伙伴 Buddhika Chamith的Java + OSGi 。


翻译自: https://www.javacodegeeks.com/2012/05/learn-by-errors-java-osgi.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/372778.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Business Component(BC)和Business Object(BO)

Siebel应用架构的一个成功的地方就是在应用里引入了BC,BO的概念,从而使得几千张关系数据表能够按照业务的含义组织成业务对象,对于业务人员而言具有了业务上的含义,而不仅仅是从技术人员的观点来对待数据(就是关系表而…

NetBeans可用性提示

的Java IDE都来了,因为在很长的路要走天的JBuilder的 (尽管JBuilder中似乎是一个值得欢迎提前在时间)。 当今的Java IDE(例如NetBeans , Eclipse , IntelliJ IDEA和JDeveloper )是非常先进的工具…

WPF 反编译后错误处理

1. 首先,手动创建一个WPF工程(WpfApplicationReflectorDemo) 2. 把生成的WpfApplicationReflectorDemo.exe 拖到ILSpy里 3.点击 File -> Save Code...: 相应的代码会生成到指定地方。 4. 打开应用程序,并且编译它,此…

JavaFX 2 GameTutorial第1部分

介绍 我相信大多数软件开发人员可能会在年轻人(年轻人)一生中的某一时刻被迫创建游戏来帮助他们学习编程语言(我知道我确实做到了)。 以前,我的第一台计算机实际上是Franklin Ace 1000 ,后来是Apple [] 。 …

虚拟现实-VR-UE4-认识UE4

VR的火热,让每个人都想参与一下, 公司在展会上面搞了一个VR的Demo,关注度超出预期,使得公司高层决定来个VR项目 所以 关于UE4 百度百科地址:http://baike.baidu.com/link?urlmEmbwOcqEuqtkfdu9lNdxVtWAkv0Q6UHZ4VgIHr…

轻松完成Birt报告

这是使用Birt插件在Eclipse中构建报告的完整指南。 Birt或Business Intelligence and Reporting工具是一种无需编写太多Java代码即可生成报告的工具。 如果您使用的是ireport,那么您知道我在说什么:)(晶体报告..毫无意义&#xff…

揭开Python科学计算的面纱

春牛春杖。无限春风来海上。便与春工。染得桃红似肉红。 春幡春胜。一阵春风吹酒醒。不似天涯。卷起杨花似雪花。 标准的Python中用列表保存一组值,可以当做数组使用,但是由于其值类型任意,所以列表中保存的是指针,这样的话保存一…

TeamCity构建依赖项

介绍 构建依存关系的主题既不重要也不是次要的。 各种构建工具从不同的角度处理此主题,从而提供各种解决方案,每种解决方案都有其优点和缺点。 熟悉发行版和快照依赖项的Maven和Gradle用户可能不了解TeamCity快照依赖项,或者认为他们与Maven…

复选框操作checked选中为true,反之为False,也可以赋值为true,false

转载于:https://www.cnblogs.com/shiluoliming/p/6518236.html

从0开始学习 GitHub 系列汇总笔记

本文学习自Stromzhang, 原文地址请移步:从0开始学习 GitHub 系列汇总 我的笔记: 0x00 从0开始学习GitHub 系列之[初识GitHub] GitHub 影响力 a.全球顶级科技公司纷纷加入 GitHub ,并贡献他们自己的项目代码 Google: https://github.com/goog…

SOA示例应用程序

SOA描述了一组用于创建松散耦合的,基于标准的,与业务相关的服务的模式,由于描述,实现和绑定之间的关注点分离,因此提供了新的灵活性。 近年来,至少在参与大多数信息技术活动的人们中,面向服务的…

Repeater 中TextBox 触发TextChanged事件

两种方法 1.TextBox 绑定TextChanged 并设置AutoPostBack "true" &#xff0c;如果不设置AutoPostBack "true"则不会触发TextChanged事件&#xff0c;然后在对应的方法里面循环Repeater查找改变项 部分代码 <ItemTemplate ><tr><td style &…

真机调试问题

1.拔掉插头重新插入 2.转载于:https://www.cnblogs.com/sanvow/p/5633976.html

ANTLR教程– Hello Word

Antlr代表另一种语言识别工具。 该工具能够为任何计算机语言生成编译器或解释器。 除了明显的用途&#xff08;例如需要解析一种真正的“大型”编程语言&#xff0c;例如Java&#xff0c;PHP或SQL&#xff09;外&#xff0c;它还可以帮助执行更小&#xff0c;更常见的任务。 每…

centOS 6.5安装python和nginx

一、安装python3.5 1、安装python3.5 2、安装pip并升级到最新 下载wget --no-check-certificate https://github.com/pypa/pip/archive/1.5.5.tar.gz 注意&#xff1a;wget获取https的时候要加上&#xff1a;--no-check-certificate tar zvxf 1.5.5.tar.gz #解压文件 cd pip…

插件化编程实现的一份糖炒栗子~~

迷茫的原因是因为想得太多&#xff0c;做得太少。因为只是 想 真的很容易&#xff0c;转瞬之间就会产生无数个念头&#xff0c;或许是该做点什么了吧。 但是整个人都是懒的&#xff0c;是废的&#xff0c;是大脑控制不住自己的行为的。解决方案唯有一步一步的去把行为变成习惯。…

用C#来学习唐诗三百首和全唐诗

Begin 最近把项目做完了&#xff0c;闲来无事&#xff0c;就想做点好玩的事情&#xff0c;刚好前几天下载了【唐诗三百首】和【全唐诗】这两个txt文件&#xff0c;正好用C#来整理一下。 然后导出QData格式&#xff0c;可以给其他软件读取。 以后弄个开机自动显示一句诗&#xf…

sts java配置tomcat_STS配置Tomcat.9.0

今天&#xff0c;心血来潮&#xff0c;弄了一下STS,按着建立WEB项目的方式建立工程。一、新建工程(FILE --NEW--Dynamic Web project)二、输入项目名称&#xff0c;TestWeb&#xff0c;然后下一步&#xff0c;点击FInish.三、新建index.jsp并打开index.jsp,书写测试成功&#x…

javaweb国际化

根据数据的类型不同&#xff0c;国际化分为2类&#xff1a;静态数据国际化和动态数据的国际化。 静态数据&#xff0c;包括 “标题”、“用户名”、“密码”这样的文字数据。 动态数据&#xff0c;包括日期、货币等可以动态生成的数据。 国际化涉及到java.util.Locale和java.ut…

20145335郝昊《网络攻防》Bof逆向基础——ShellCode注入与执行

20145335郝昊《网络攻防》Bof逆向基础——ShellCode注入与执行 实验原理 关于ShellCode&#xff1a;ShellCode是一段代码&#xff0c;作为数据发送给受攻击服务器&#xff0c;是溢出程序和蠕虫病毒的核心&#xff0c;一般可以获取权限。我们将代码存储到对方的堆栈中&#xff0…