草庐IT

java - 类加载隔离在 jboss 5.1.x 中工作吗

coder 2024-03-21 原文

我有一个非常标准的 java 应用程序,它使用 maven 一些非常常见的库,包括

  • Spring
  • hibernate ORM
  • hibernate validator
  • Log4j

该应用程序由两个共享许多共同依赖项的 war 模块组成。

在开发过程中,我们同时使用了 jetty 和 tomcat,一切正常。现在我们即将部署到生产环境中,我们对这个环境有一些限制:

  • 应用程序必须部署在一个已配置的 jboss 5.1.x 实例中,该实例在 $JBOSS_HOME/common/lib/和 $JBOSS_HOME/server//lib/下有大量的库,显然有很多重复的 jar在这些目录中(尤其是 log4j 和 hibernate 验证的东西)
  • 我们不能更改 JBoss 配置或包含的库
  • 我们需要提供一个单一的 ear 存档作为要部署的最终 Artifact
  • 一些应用程序代码依赖于比提供的库更新的库

maven最终生成的ear结构为

application.ear
├── META-INF
│   ├── application.xml
│   └── jboss-classloading.xml
├── lib
│   ├── long list of shared jars
│   ├── ...
│   ├── // some of key libraries which also are in AS lib folder
│   ├── hibernate-validator-4.3.1.Final.jar
│   ├── jaxb-impl-2.1.10.jar
│   ├── log4j-1.2.17.jar
│   ├── slf4j-api-1.5.5.jar
│   ├── slf4j-log4j12-1.5.5.jar
│   └── validation-api-1.0.0.GA.jar
├── webapp1.war
└── webapp2.war

在我们的 pom 中,仅有的两个标记为提供的 Artifact 是这些,因此我们需要在容器中提供它们。

<dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>servlet-api</artifactId>
    <version>${servlet.version}</version>
    <scope>provided</scope>
</dependency>

<dependency>
    <groupId>javax.xml.bind</groupId>
    <artifactId>jaxb-api</artifactId>
    <version>${jaxb.version}</version>
    <scope>provided</scope>
</dependency>

然而,当我们在 jboss 中部署 ear 时,我们遇到了很多类加载问题(稍后我将列出其中的一些)。我们想要获得的是让 jboss 以 WAR->EAR->Server 的顺序加载库。通过这种方式,我们可以使用较新的库并安全地从与应用程序服务器共享的部署库中排除。为了获得这个,我创建了一个 maven jboss 配置文件,其中列出了所提供的公共(public)库(log4j、slf4j、resteasy 和其他一些),并在 ear 中包含所有其他库,包括 AS 上存在的较新版本的 jar。

在阅读了很多关于 JBoss 5.x 中的 jboss 类加载隔离的帖子后,我正在尝试的配置是 this article 中包含的配置。它链接到许多不同的来源,并且应该有效。

我所做的另一个尝试是部署为两个 WAR 以查看是否有变化。在那种情况下,我在其中一个 war 模块中使用此配置,并且我试图仅部署该 war

<classloading xmlns="urn:jboss:classloading:1.0"
              domain="myapp.war"
              parent-domain="DefaultDomain"
              parent-first="false"
              export-all="NON_EMPTY"
              top-level-classloader="true"
              import-all="true">
</classloading>

错误保持不变。

我不知道该怎么做,也因为我找不到任何关于 jboss-classloading.xml 文件的官方文档,其中包含参数解释和具体用例。

我的问题是类加载隔离在 JBoss 5.1.x 中是否有效?可靠吗?如果是如何获取WAR->EAR->Server类加载?

或者,我如何才能完全排除服务器库并仅使用我的存档中包含的 JAR?在这种情况下,我是否还需要包含原始提供的依赖项,即 servlet-api、jaxb-api 和 xml-apis?

类加载我找到的文章

当前部署问题

使用当前配置,我们遇到的第一个错误就是这个错误(省略堆栈跟踪)

13:10:11,972 INFO  [STDOUT] 13:10:11,969 ERROR [ContextLoader] Context initialization failed
org.springframework.beans.factory.BeanDefinitionStoreException: Unexpected exception parsing XML document from ServletContext resource [/WEB-INF/applicationContext.xml]; nested exception is java.lang.ClassCastException: org.apache.xerces.jaxp.DocumentBuilderFactoryImpl cannot be cast to javax.xml.parsers.DocumentBuilderFactory

通过查看 some posts我们可以通过将其放入我们的 maven jboss 配置文件来解决这个问题

<dependency>
    <groupId>xml-apis</groupId>
    <artifactId>xml-apis</artifactId>
    <version>1.0.b2</version>
    <scope>provided</scope>
</dependency>

在那之后,我们在 spring 上下文中使用此行声明为 bean 的 hibernate validator 对象的实例化出现了很多错误

<!-- Hibernate validator stuff -->
<bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean"/>

这里是错误

16:52:58,430 ERROR [ContextLoader] Context initialization failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'validator' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is java.lang.NoSuchMethodError: org.jboss.logmanager.LogContext.getAttachment(Ljava/lang/String;Lorg/jboss/logmanager/Logger$AttachmentKey;)Ljava/lang/Object;
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1455)

如果我删除捆绑版本的 hibernate validator ,我会丢失一些在应用程序代码中使用的有用 validator ,并且我会收到有关缺少注释的错误

java.lang.NoClassDefFoundError: [Ljavax/validation/constraints/Pattern$Flag;

所以我被这个问题困住了,请指教。

最佳答案

类加载隔离在 Jboss 5 中工作得非常顺利。引用 https://community.jboss.org/wiki/ClassLoadingConfiguration?_sscc=t了解更多详情。

关于java - 类加载隔离在 jboss 5.1.x 中工作吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20006055/

有关java - 类加载隔离在 jboss 5.1.x 中工作吗的更多相关文章

  1. ruby - 如何在续集中重新加载表模式? - 2

    鉴于我有以下迁移:Sequel.migrationdoupdoalter_table:usersdoadd_column:is_admin,:default=>falseend#SequelrunsaDESCRIBEtablestatement,whenthemodelisloaded.#Atthispoint,itdoesnotknowthatusershaveais_adminflag.#Soitfails.@user=User.find(:email=>"admin@fancy-startup.example")@user.is_admin=true@user.save!ende

  2. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  3. ruby - RuntimeError(自动加载常量 Apps 多线程时检测到循环依赖 - 2

    我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("

  4. ruby-on-rails - 使用 config.threadsafe 时从 lib/加载模块/类的正确方法是什么!选项? - 2

    我一直致力于让我们的Rails2.3.8应用程序在JRuby下正确运行。一切正常,直到我启用config.threadsafe!以实现JRuby提供的并发性。这导致lib/中的模块和类不再自动加载。使用config.threadsafe!启用:$rubyscript/runner-eproduction'pSim::Sim200Provisioner'/Users/amchale/.rvm/gems/jruby-1.5.1@web-services/gems/activesupport-2.3.8/lib/active_support/dependencies.rb:105:in`co

  5. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  6. java - 我的模型类或其他类中应该有逻辑吗 - 2

    我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

  7. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

  8. Observability:从零开始创建 Java 微服务并监控它 (二) - 2

    这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/

  9. 【Java 面试合集】HashMap中为什么引入红黑树,而不是AVL树呢 - 2

    HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候

  10. ruby-on-rails - 从应用程序中自定义文件夹内的命名空间自动加载 - 2

    我们目前正在为ROR3.2开发自定义cms引擎。在这个过程中,我们希望成为我们的rails应用程序中的一等公民的几个类类型起源,这意味着它们应该驻留在应用程序的app文件夹下,它是插件。目前我们有以下类型:数据源数据类型查看我在app文件夹下创建了多个目录来保存这些:应用/数据源应用/数据类型应用/View更多类型将随之而来,我有点担心应用程序文件夹被这么多目录污染。因此,我想将它们移动到一个子目录/模块中,该子目录/模块包含cms定义的所有类型。所有类都应位于MyCms命名空间内,目录布局应如下所示:应用程序/my_cms/data_source应用程序/my_cms/data_ty

随机推荐