WebLogic常见问题

简介:

myeclipse+weblogic10的配置,配置成功 


运行中可能失败,由于weblogic10不稳定,重启机器后可以使用了 


web工程使用到hibernate3时可能出现问题 

ClassNotFoundException: org.hibernate.hql.ast.HqlToken 

参考http://blog.chinajavaworld.com/entry.jspa?id=829 

把本地的antlr.jar包考到weblogic.jar所在目录,在myeclipse配置服务器的path选项中添加这个antlr.jar包后运行OK 


下面转载了可能出现的其他问题和解决方法: 

1.其中发现jmesa处理时找不到配置文件,对应下面的问题6,我是改用archive方式发布后就OK了 


2.CXF在WebLogic10.3上的部署出现问题:org.apache.cxf.js.rhino.DOMPayloadProvider" failed to preload 

解决方法是web.xml文件的头改为<web-app xmlns="http://java.sun.com/xml/ns/j2ee"> 


3.有<%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt" %>无法处理,该工程中用到的jstl.jar包来自MyEclipse,找一个放到本工程的lib库下,可解决 


4.避免在lib库中出现重复包 


5.Hibernate-Validate-4.0.jar的不支持,用到该包,要用以前的Hibernate-Validate.jar包 


OS:Windows XP 

WebApp Server:Tomat5.5 WebLogic  server 10 (中文版) 

IDE:Bea workshop for weblogic platform。 

一.IDE注意事项 

创建动态web项目,选择是否共享j2ee库,如果共享,则需要域的共享库里面包含项目所需的库,比如beeHive netUi; 

不共享,则将所需的库拷贝到WEB-INF/lib目录,并自动创建相关配置文件于WEB-INF下 

如果访问页面时出现如下错误: 

index.jsp:2:4: 使用该 URI 无法找到标记库。可能是因为 URI 不正确或解析 .tld 文件时出错。 

<%@taglib uri="http://beehive.apache.org/netui/tags-html-1.0" prefix="netui"%> 

请删除多余的配置文件,或者重新建立一个工程,在向导第二页选择好正确的配置。 


二.WebLogic基础知识 

一个域可以包括多个服务器,应用程序依赖于某个服务器,通过部署-〉某应用程序-〉目标 来配置 

wl_server是weblogic默认域,通过开始菜单-〉Bea products->tools->Weblogic Server来启动 

要创建自己的域,则可以通过开始菜单-〉Bea products->tools->Configuration wizard来创建 

登录地址:http://localhost:7001/console/login/LoginForm.jsp 

登录用户密码:weblogic/weblogic 


1.部署war之后,测试时发生错误: 

Error   503--Service   Unavailable   

From   RFC   2068   Hypertext   Transfer   Protocol   --   HTTP/1.1: 

..... 

解决办法:一般是在刚刚激活更改后,就进行测试,还需要将该应用程序启动,状态为“活动”之后再测试就可以了。 


2.连接池测试时出错: 

Warning! Connectivity to backend database not verified. This is either because required connection pool attribute "TestConnectionsOnReserve" has not been enabled, or an invalid value has been specified for attribute "TestTableName". Please check the server log for more details.. 

配置连接缓冲池,在“高级”中选中“保留时测试连接”即可。此时需要先激活更改再进行测试。否则还会报错。 


3.jdbc jndi错误: 

javax.naming.NameNotFoundException: Unable to resolve 'jdbc_fbysss. Resolved ''; remaining name 'jdbc_fbysss' 

首先要在控制台中点击左边的控制栏中的服务->JDBC新建一个数据源,数据源名称无所谓,jndi name一定要注意,比如取名叫jdbc_fbysss,而且,jdbc源必须依赖于一个server。否则无法启动。 

对于Spring项目,修改applicationContext.xml的dataSource,(Tomcat的连接池在这里就不需要了)。 

  <!-- 数据源缓冲池 -->  <bean id="dataSource"   class="org.springframework.jndi.JndiObjectFactoryBean">    

        <property name="jndiName" value="jdbc_fbysss"/><!--两者要一样--> 

        <property name="resourceRef"> 

          <value>false</value> 

        </property>   

        </bean> 


4.xml校验错误 

(1)hbm.xml 

org.dom4j.DocumentException: unknown protocol: platform. Nested exception: unknown protocol: platform 

这个经检查是workshop导出时 ,hbm.xml文件生成错误。修改过来就好了 

(2)struts-config.xml 

正式部署时出现异常: 

ERROR Digester        []: Parse Error at line 2 column 

15: Document root element "struts-config", must match DOCTYPE root "null". 

org.xml.sax.SAXParseException: Document root element "struts-config", must match 

DOCTYPE root "null". 

需要在struts-config.xml中第二行加入<!DOCTYPE   struts-config   PUBLIC   "-//Apache   Software   Foundation//DTD   Struts   Configuration   1.2//EN"   "http://struts.apache.org/dtds/struts-config_1_2.dtd"> 


5.ServletApi实现不一致情况 

发现一个奇怪的现象,tomcat中,一个servlet的子类,如果没有声明init方法,会自动执行父类的init方法,而weblogic不会。 

解决办法是显式声明init,super.init(); 


6.莫名其妙空指针错误 

完整错误信息: 

java.io.FileNotFoundException: F:\bea\wlserver_10.0\samples\domains\workshop\servers\cgServer\tmp\_WL_user\prj_fbysss\mlh5uz\war (拒绝访问。) 

        at java.io.FileInputStream.open(Ljava.lang.String;)V(Native Method) 

        at java.io.FileInputStream.<init>(FileInputStream.java:106) 

        at workshop.util.filesystem.file.WlFileSystem.getInputStream(WlFileSyste 

m.java:148) 

        at workshop.util.filesystem.FS.getInputStream(FS.java:262) 

        at javelin.jsp.JspParser.readStaticInclude(JspParser.java:3261) 

        at javelin.jsp.JspParser.parseStaticInclude(JspParser.java:3198) 

        at javelin.jsp.JspParser.processImplicitIncludes(JspParser.java:3289) 

        at javelin.jsp.JspParser.jspParse(JspParser.java:703) 

        at javelin.jsp.JspParser._parse(JspParser.java:504) 

        at javelin.jsp.JspParser.parse(JspParser.java:497) 

        at javelin.jsp.JspAnalyzer.parseFile(JspAnalyzer.java:113) 

        at javelin.jsp.JspAnalyzer.parse(JspAnalyzer.java:101) 

        at javelin.ProxySourceFile.parse(ProxySourceFile.java:117) 

        at javelin.SourceFile.getAst(SourceFile.java:542) 

        at javelin.SourceFile.getAst(SourceFile.java:516) 

        at javelin.ProxySourceFile.codeGen(ProxySourceFile.java:215) 

        at javelin.SourceFile.codeGen(SourceFile.java:310) 

        at javelin.client.ClientUtilsImpl$CodeGenJob.run(ClientUtilsImpl.java:11 

05) 

        at javelin.client.Job.performJob(Job.java:81) 

        at javelin.client.ThreadPool$WorkerThread.run(ThreadPool.java:215) 

<2008-8-23 下午07时15分11秒 CST> <Error> <HTTP> <BEA-101017> <[weblogic.servlet. 

internal.WebAppServletContext@36b25e - appName: prj_fbysss, name: 'prj_fbysss', context-path: '/prj_fbysss] Root cause of ServletException. 

java.lang.NullPointerException 

        at javelin.jsp.JspAnalyzer.parse(JspAnalyzer.java:104) 

        at javelin.ProxySourceFile.parse(ProxySourceFile.java:117) 

        at javelin.SourceFile.getAst(SourceFile.java:542) 

        at javelin.SourceFile.getAst(SourceFile.java:516) 

        at javelin.ProxySourceFile.codeGen(ProxySourceFile.java:215) 

        Truncated. see log file for complete stacktrace 


最后发现是web.xml中<include-coda/>一句不对,去掉就好了,很怪异。 

  <taglib> 

  <taglib-uri>http://www.sss.com/select</taglib-uri> 

  <taglib-location>/WEB-INF/tlds/select.tld</taglib-location> 

     </taglib> 

  <taglib> 

  <taglib-uri>http://www.sss.com/tree</taglib-uri> 

  <taglib-location>/WEB-INF/tlds/tree.tld</taglib-location> 

     </taglib>     

  <!--web 项目配置--> 

  <jsp-property-group> 

   <description> 

    WEB项目配置 

   </description> 

   <display-name>JSPConfiguration</display-name> 

   <url-pattern>*.jsp</url-pattern> 

   <el-ignored>false</el-ignored> 

   <page-encoding>gbk</page-encoding> 

   <scripting-invalid>false</scripting-invalid> 

   <!--这句居然引起webloic错误!!!! include-coda/--> 

  </jsp-property-group> 

</jsp-config> 


7.类冲突问题 


(1)JSTL解析失败 

index.jsp:1:1: validator 类 "org.apache.taglibs.standard.tlv.JstlCoreTLV" 失败,出现如下异常: "java.lang.ClassCastException: weblogic.xml.jaxp.RegistrySAXParserFactory"。 

<%@page contentType="text/html;charset=gbk" language="java"%> 

项目属性-〉项目构面中的设置将记录在.setting/org.eclipse.wst.common.project.facet.core.xml文件中。 

最后是把prefer-web-inf-classes设置为false就可以了。 


(2)HQL语句执行失败 

org.springframework.orm.hibernate3.HibernateQueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken 

这种情况是包版本冲突,必须设置prefer-web-inf-classes设置为true。 

这样一来,有的包需要true,有的需要false,怎么办?Weblogic的确够恶心的。JSTL的包都已经放webapp下了,设置prefer-web-inf-classes设置为ture还不行,只好采取以下稍显麻烦的方法: 

在workshop开发环境下,启动的服务器目录是 

F:\bea\wlserver_10.0\samples\domains\workshop\bin 

修改启动脚本startWebLogic.cmd 

找到set CLASSPATH=%SAVE_CLASSPATH%,在后面加入 

@REM sss added 

set PRE_CLASSPATH=%WL_HOME%\server\lib\antlr-2.7.6rc1.jar; 

set CLASSPATH=%PRE_CLASSPATH%;%CLASSPATH% 

其中,antlr-2.7.6rc1.jar包需要拷贝到F:\bea\wlserver_10.0\server\lib下。 

正式发布的时候,需要修改对应域目录下的启动脚本 

比如f:\bea\user_projects\domains\fbysssDomain\bin\startWebLogic.cmd 

8.部署问题 

部署时出现如下错误: 

<2008-8-23 下午07时37分42秒 CST> <Warning> <Deployer> <BEA-149124> < 

Failures were detected while initiating redeploy task for application 'prj_fbysss'. Error is: ' 

[Deployer:149163]The domain edit lock is owned by another session in non-exclusi 

ve mode - this deployment operation requires exclusive access to the edit lock a 

nd hence cannot proceed.'> 

解决:进入http://localhost:7001/console,释放配置,再次部署即可。 

注:更新war:必须在删除该应用,并激活更改之后才能覆盖。 

但是用war方式,获取资源路径的方法和tomcat不同,存在臭名昭著的getRealPath等问题,移植困难,所以用目录方式部署比较好。 

具体方法:先把war解压,然后在weblogic控制台里面选择目录部署。 



本文转自 Mr_sheng 51CTO博客,原文链接:http://blog.51cto.com/sf1314/2056587

相关文章
|
3月前
|
Java 应用服务中间件 Linux
centos7安装weblogic
centos7安装weblogic
|
负载均衡 Java 应用服务中间件
Weblogic的了解、安装及其使用(三)
Weblogic的了解、安装及其使用
1378 0
|
Oracle Java 关系型数据库
Weblogic的了解、安装及其使用(二)
Weblogic的了解、安装及其使用
1013 0
|
开发框架 Kubernetes 监控
Weblogic的了解、安装及其使用(一)
Weblogic的了解、安装及其使用
2466 0
|
安全 Oracle Java
Oracle Weblogic--CentOS Linux 8.5.2安装weblogic11G
Weblogic在centos上详细安装步骤及安装过程中可能遇到的问题
338 0
Oracle Weblogic--CentOS Linux 8.5.2安装weblogic11G
|
Oracle 关系型数据库 Java
EOS Platform 7.2下安装weblogic插件
在实际工作中,需要用到EOS Platform,这是一个基于Eclipse的开发工具,自带了Tomcat,可以满足大部分需要,但是有时候需要使用Weblogic,这就得手动安装Weblogic插件了。这个过程与Eclipse相同(Eclipse下安装weblogic插件),本文中在EOS Platform 7.2中安装Weblogic插件。
193 0
EOS Platform 7.2下安装weblogic插件
|
Oracle 关系型数据库 Java
Eclipse下安装weblogic插件
安装好weblogic dev版本(Windows下安装weblogic dev版本),可以在Eclipse中安装weblogic server tools插件,直接连接到weblogic server,发布、部署、调试都变得简单些。
691 0
Eclipse下安装weblogic插件
|
Oracle 关系型数据库 Java
Windows下安装weblogic dev版本
在开发过程中,有一种情况是比较尴尬的:需要用到某个软件,但是只需要用到这个软件中的一小部分功能,这样既浪费的磁盘空间,又浪费了CPU空间。比如Weblogic,完整版包括很多功能,但是开发过程中,只是需要创建数据源、部署项目,然后进行测试即可。所以开发过程中,需要一款简化的Weblogic(Weblogic开发版)是挺有必要的(如果电脑配置比较壕,也可以任性的使用完整版)。
332 0
Windows下安装weblogic dev版本