java11+osgi_错误学习:Java + OSGi

java11+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)。现在捆绑软件A直接连接到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

java11+osgi

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

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

相关文章

集群没有leader_ZooKeeper 集群中 Leader 与 Follower 的4种数据同步策略

首先要声明一点,zk集群中,leader服务器有着比较重要的存在,Follower 服务器只是处理非事务性请求,leader服务器主要负责事务性请求,Follower 服务器在遇到事务性请求以后还是会转发给leader服务器处理,所以…

JavaOne 2015:高级模块化开发

JavaOne 2015看到了Project Jigsaw团队关于Java 9中的模块化的一系列讨论 。它们都是非常有趣的,并且充满了宝贵的信息,我敦促每个Java开发人员都注意它们。 除此之外,我想给社区一种搜索和引用它们的方法,因此我在这里总结一下&…

action怎么获得 ajax date参数_ajax()gt;load()事件的新用法!!!

load()函数用于从服务器加载数据,并使用返回的html内容替换当前匹配元素的内容。load()函数默认使用GET方式,如果提供了对象形式的数据,则自动转为POST方式。load()函数只会替换每个匹配元素的内部内容(innerHTML)。你还可以在URL字符串后面追…

无显示器u盘安装centos_最新版 CentOS 8.1.1911 安装教程及常见问题图文详解

基于笔记本(华硕)操作,使用软碟通(UltraISO)制作的系统启动盘(U盘,内存大于8G)操作可自行百度,非常简单(或可留言,择情况出一期U盘制作启动盘教程)。a、登录 centos 官网下载镜像文件官网地址:https://www.centos.org阿…

bom实现方块移动_从0开始实现一个俄罗斯方块

写在前面得话:这篇文章主要记录了我是怎么一步一步写出俄罗斯方块,整个代码用的函数编程,主要是为了让一些不熟悉es6, 面向对象写法得 新手能更容易看明白,全部得代码中都是一些js的基础知识,很容易理解。要说有点麻烦…

cli3解决 ie11语法错误 vue_基于 Vue + Koa2 + MongoDB + Redis 实现一个完整的登录注册...

项目地址:https://github.com/caochangkui/vue-element-responsive-demo/tree/login-register通过 vue-cli3.0 Element 构建项目前端,Node.js Koa2 MongoDB Redis 实现数据库和接口设计,包括邮箱验证码、用户注册、用户登录、查看删除用户…

gwt 嵌入html_GWT和HTML5画布演示

gwt 嵌入html这是我对GWT和HTML5 Canvas的第一个实验。 我的第一个尝试是创建矩形,仅用几行代码就得出了这样的内容: 码: public class GwtHtml5 implements EntryPoint {static final String canvasHolderId "canvasholder";sta…

tez什么意思_传统数仓和大数据数仓的区别是什么?

概念与容器为什么先说这个,其实很简单:因为绝大多数人都把这两个概念混为一谈。然后就会出现各种各样的问题:oracle不是数据库么,怎么又是数据仓库?Hive不是数据仓库么?怎么又是数据库?数据仓库…

华为M2平板打不开云课堂_能运行PC应用的安卓生产力平板:华为MatePad Pro 5G登场...

当手机屏幕无法承担更复杂的工作任务,当PC重量不能满足更随性的移动办公,拥有全面屏和便携优势的平板电脑或是中间值,但前提是其必须拥有足够强大的生产力。5月27日华为在国内上市的其首款5G平板——华为MatePad Pro 5G,就是5G时代…

soa示例_SOA示例应用程序

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

body curl 设置post_curl 命令详解

常用参数常用参数分类# 调试类-v, --verbose 输出信息-q, --disable 在第一个参数位置设置后 .curlrc 的设置直接失效,这个参数会影响到 -K, --config -A, --user-agent -e, --referer-K, --config FILE …

NetBeans Java EE技巧7:忽略的Java类和XHTML编辑器快捷方式

有时,最被忽略的是IDE最有用的功能。 在本文中,我将概述在开发Java EE应用程序时可以使用的五个NetBeans Java和XHTML编辑器快捷方式。 #1 –轻松修复命名空间和类 也许您已经向尚未声明名称空间的视图中添加了新的JSF标记,或者…

python学习第三十二节(进程间通信、进程池、协程)

当多线程创建完毕之后,start并没有了立刻运行,依旧需要和其他线程抢CPU的资格,只是时间很短。进程之间的通信分为两种,queue和pipe 1 import multiprocessing2 def foo(q):3 q.put([1,hello,True])4 if __name____main__:5 …

备份ad_IT管理公开课——备份恢复解决方案

时间:2020年5月28日 14:00内容:调查显示,44%的客户面临意外删除或修改数据,如果没有提前备份,这些数据是很难恢复的。RecoveryManager Plus是一款针对AD域,Exchange,Sharepoint以及O…

Ajax中的url使用规则

Ajax中的url使用规则Ajax中的url使用规则如下: 先封装项目访问地址: String basePath request.getScheme() "://" request.getServerName() ":" request.getServerPort() request.getContextPath();然后在js中定义&#xff1…

[网络管理]全双工与半双工的差别

[网络管理]全双工与半双工的差别 同事说新办公室的网络一直不稳定,常常掉线延迟。检查进口线路和更换转接网线。都无法解决这个问题。预计是不是进口网线中一根或者2根短路,那就改动下网卡属性吧。 把自适应改成全双工10M模式,測试OK。全双工…

echarts大屏模板_完整的可视化大屏分享,科技感十足,各行业直接就能用

你的老板有没有要求过你做一个可视化大屏?或许在你看来,这就是一个无理的需求,很简单啊,做几个动态图表,直接投影到屏幕上不就行了?就算做出来能用数据增长业务吗?不懂为什么要拍脑袋做大屏&…

Java面试基础知识(1)

1、final, finally, finalize的区别final:修饰符(关键字)如果一个类被声明为final,没有子类也不能被继承。因此一个类不能既被声明为 abstract的,又被声明为final的。将变量或方法声明为final,可以保证它们…

bird 报表_轻松完成Birt报告

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

通过kubeadm安装kubernetes 1.7文档记录[docker容器方式]

参照了网上N多文档,不一一列表,共享精神永存!!!! 获取所有安装包 安装包分为两类,rpm安装包和docker镜像 rpm安装包 rpm为以下四个 kubeadm-1.7.0-0.x86_64.rpm kubectl-1.7.0-0.x86_64.rpm ku…