zoukankan      html  css  js  c++  java
  • web工程迁移---jboss5迁移到jboss6

    这几天在做web工程的迁移,从jboss 5迁移到jboss 6.3.

    在做迁移的过程中遇到了一些问题,在这里记录一下。

    首先来看一下jboss5和jboss6.3的区别:

                  

        上面两幅目录截屏左边的是jboss5.1的,右边的是jboss6.3的,别的不多说,仅从目录便可以看出,jboss6.3使用的是模块化加载jar包的方式,并且也包含了jboss之后版本的domain和standalone两种启动方式。所以说jboss5和jboss6.3从结构上来讲其差别就是比较大的。此外,jboss6.3的配置是standalone.xml文件,避免了jboss5中混乱的配置结构。

         接下来讲一下我在迁移的过程中遇到的一些问题,由于涉及到项目的保密性,所以代码部分会有所省略。

         在该项目中,使用JDK1.6.

         1、启动问题

              在拿到jboss6.3的zip包后,第一件事便是解压,配置环境变量然后运行了,我这里使用的是standalone的启动方式,单击standalone.bat文件便可。

              但是单击后出现下图所示:

         

              注:-Xms:初始Heap大小,使用的最小内存 -Xmx:java heap最大值,使用的最大内存

              从log中可以看出,使用的内存不够,无法创建虚拟机。

              原因:jboss的版本是64位的,而我的工作环境的jdk1.6是32位的,其导致的直接结果便是无法调节内存

              解决:将32位的jdk换成64位的(环境限定无法更改)

            将内存jboss启动时的内存调小(在log中显示其使用的最大和最小内存)

              我使用的是第二种方法,在standalone.bat文件的附近还有一个standalone.conf.bat文件,使用记事本打开该文件,找到下图位置:

        

              改变其Xms和Xmx的大小便可,我使用的是512.改完后启动成功。

      2、数据源的配置

              在jboss5中,配置数据源的方式比较简单,在segment(如server下的default节点)下的lib文件夹中加入数据库驱动jar,然后在segment的deploy文件夹中添加name-ds.xml文件,jboss便可以自动配置数据源。

         而jboss6.3中,进行了模块化设计,所以与jboss的配置有所不同,配置方式可参考wildfly8+jpa EntityBean 简单入门

         在配置的过程中,原本jboss5中的-ds.xml文件中的数据源为datasource1.我一开始使用的方式为全部照抄。结果出现异常:         

    at java.lang.Thread.run(Thread.java:662) [rt.jar:1.6.0_26]
    Caused by: javax.xml.stream.XMLStreamException: javax.xml.stream.XMLStreamException: ParseError at [row,col]:[150,5]
    Message: "JBAS010471: Jndi name have to start with java:/ or java:jboss/"

         即所有的jndi都要以java:/或java:jboss/开头

         这也意味着,你的工程中的所有的数据源都将失效(┬_┬)

             ####注:仔细看了jboss5后,发现jboss5是可以通过jboss:datasourceName的形式访问的

          3、工程中的包和jboss中的包冲突

             在迁移的过程中了解到了本项目原本是用weblogic中迁移到jboss5的,现在准备迁移到jboss6.3中,在jboss5的时候需要额外的jar:weblogic

             由于使用的是模块化,所以要在jboss的moudle中按规则加入jar包,然后在standalone.xml文件中配置,如下所示:  

        <subsystem xmlns="urn:jboss:domain:ee:1.1">
                <global-modules>
                    <module name="XXX.weblogic" slot="main"/>               
                </global-modules>            
                <spec-descriptor-property-replacement>false</spec-descriptor-property-replacement>
                <jboss-descriptor-property-replacement>true</jboss-descriptor-property-replacement>
                <annotation-property-replacement>false</annotation-property-replacement>
            </subsystem>

        如果要在加jar包,则可以在global-modules节点中添加。

          以上步骤看似正确,实则给自己挖了一个大坑。运行后log中有如下提示:  

    14:27:49,754 INFO  [org.apache.catalina.core.ContainerBase.[jboss.web].[default-host].[/home]] (ServerService Thread Pool -- 58) JBWEB000264: Marking servlet DownloadServlet as unavailable
    14:27:49,754 ERROR [org.apache.catalina.core.ContainerBase.[jboss.web].[default-host].[/home]] (ServerService Thread Pool -- 58) JBWEB000289: Servlet DownloadServlet threw load() exception: java.lang.ClassCastException: XXX.XXX.XXX.core.servlet.DownloadServlet cannot be cast to javax.servlet.Servlet
        at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1154) [jbossweb-7.4.8.Final-redhat-4.jar:7.4.8.Final-redhat-4]
        at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:1100) [jbossweb-7.4.8.Final-redhat-4.jar:7.4.8.Final-redhat-4]

         百度的结果为:这个异常很常见,应该是你导入的jsp的jar包和servlet的jar包重复导致的冲突

         表示走入死胡同,所有的都检查了,就是没有想到我之前导入的weblogic包。。。最后在大神的帮助下,找到了这个问题,分分钟解决

      

       4、配置文件问题

         原本在jboss5中,除了部署工程之外,还需要在jboss下segment中的conf文件夹中添加一份配置文件:conf.properties

             而在jboss6中,segment中只有configuration文件夹,没有conf文件夹,所以我暂时将文件放在了configuration中。

         启动jboss6后,出现异常:

    07:01:24,966 ERROR [WebAppListener] (ServerService Thread Pool -- 52) E/2016.03.28 at 07:01:24|java.io.FileNotFoundException: nullconfconfig.properties (The system cannot find the path specified): xx.xx.xx.xx.ConfigurationException: java.io.FileNotFoundException: nullconfconfig.properties (The system cannot find the path specified)

             这段log,是由程序中的logging打印出来的,从这段log中可以看出是找不到配置文件,并且其中的地址还很神奇的出现了一个null,我首先尝试将配置文件放到我自己创建的在standalone中的一个conf文件夹中,但还是会报这个错误,所以看代码(简写):

    final String serviceInstance = System.getProperty("jboss.server.home.dir") + “/conf/conf.properties";

             在log中的null就是应为 System.getProperty("jboss.server.home.dir") 导致,百度之后,发现"jboss.server.home.dir"JBOSS自带环境变量,其表示的方式为:  jboss.server.home.dir:D:Tools2EclipsePluginJBossjboss-5.1.0.GAserversegment

             解决方法为:在standalone.xml中,添加定义,我这里使用的是一种比较简单的方式:

        首先命令行cd到standalone.bat目录,然后输入:

    standalone.bat -Djboss.server.home.dir=D:Tools2EclipsePluginJBossjboss-eap-6.3standalone

             这样一来,在jboss启动的时候便设置好了变量,那么程序中就可以获取到变量的值了。

      5、数据库驱动问题

              在上文中已经添加好了数据库连接池,但是在启动的时候,会出现一个异常:

    09:55:06,936 INFO  [] (ServerService Thread Pool -- 54) O/2016.03.28 at 09:55:06|    ..[0]
     | JdbcConf.setConnProperties fukey_DbPool=java:jboss/datasources/dbpool connProperties=[{fukey_DbPool=java:jboss/datasources/dbpool}]
    09:55:06,936 ERROR [stderr] (ServerService Thread Pool -- 54) javax.naming.NameNotFoundException: Error looking up jboss/datasources/dbpool, service service jboss.naming.context.java.jboss.datasources.dbpool is not started
    .......
    service jboss.jdbc-driver.jtds (missing) dependents: [service jboss.data-source.java:jboss/datasources/dbpool, service jboss.driver-demander.java:jboss/datasources/dbpool1, service jboss.driver-demander.java:jboss/datasources/dbpool2, service jboss.driver-demander.java:jboss/datasources/dbpool3, JBAS014799: ... and 17 more ]

        这里的log分为两部分,上一部分描述的是在启动国过程中调用jndi时发现,数据源没有启动;下一部分讲的是没有找到驱动包。

            在该工程中,使用的数据库驱动是jtds包,连接的是sqlserver,数据源的配置我是按照文档中的示例改写的,所以一直以为是对的,下面是在standalone.xml中添加的驱动:   

    <drivers>
      <driver nam e="h2" module="com.h2database.h2">
        <xa-datasource-class>org.h2.jdbcx.JdbcDataSource</xa-datasource-class>
      </driver>
      <driver nam e="jtds" module="net.sourceforge">
        <xa-datasource-class>net.sourceforge.jtds.jdbc.Driver</xa-datasource-class>
      </driver>
    </drivers>

            上面的就是,没有改过的,第一个驱动是jboss自带的h2,第二个是我自己写的jtds,由于我之前做过jboss8配置mysql的数据源,也是使用驱动做的配置,并且连接是成功的,所以下意识的认为这也是可以的,后来在一篇国外的博客中发现,在驱动的配置中,除了<xa-datasource-class>这个标签之外,还有<driver-class>标签,专门用于Driver类型的一个标签,这个标签我也查了一下jboss6的开发文档,有写,但只是在一个表格中提了一下,没有示例容易忽略

     

            将其改为:

    <drivers>
      <driver nam e="h2" module="com.h2database.h2">
        <xa-datasource-class>org.h2.jdbcx.JdbcDataSource</xa-datasource-class>
      </driver>
      <driver nam e="jtds" module="net.sourceforge">
        <driver-class>net.sourceforge.jtds.jdbc.Driver</driver-class>
      </driver>
    </drivers>

           便可以连接成功。

    ***未解决:如何将4中的变量复制写入standalone.bat文件或是run.bat

      以上就是我在做迁移的时候遇到的几个比较深刻的问题。

         由于要配置jboss6.3,这里给一个jboss6的技术文档

         

  • 相关阅读:
    HDU-1102 Constructing Roads ( 最小生成树 )
    POJ-1287 Networking ( 最小生成树 )
    HDU-1272 小希的迷宫 ( 并查集 )
    Java基本数据类型、关键字
    观察者模式
    Android系统启动过程分析
    Activity启动过程源码分析(Android 8.0)
    Okhttp解析—Okhttp概览
    Okhttp解析—Interceptor详解
    Okhttp源码分析--基本使用流程分析
  • 原文地址:https://www.cnblogs.com/welv/p/5321512.html
Copyright © 2011-2022 走看看