`
tomrose
  • 浏览: 147469 次
  • 来自: ...
社区版块
存档分类
最新评论

JBOSS 开发ejb时碰壁

阅读更多
[原创] 在JBoss服务器上开发 EJB3 应用的碰壁过程
我的JBoss服务器安装在 D:\jboss420GA 目录下。
为了开发Entity Bean映射Oracle的Table,我配置OracleDS数据源:
1、从 D:\jboss420GA\docs\examples\jca 将配置文件 oracle-ds.xml 复制到 D:\jboss420GA\server\default\deploy 下。
2、编辑修改oracle-ds.xml的内容:
<?xml version="1.0" encoding="UTF-8"?> <datasources> <local-tx-datasource> <jndi-name>OracleDS</jndi-name> <connection-url>jdbc:oracle:thin:@localhost:1521:lw</connection-url> <driver-class>oracle.jdbc.driver.OracleDriver</driver-class> <user-name>scott</user-name> <password>tiger</password> <exception-sorter-class-name> org.jboss.resource.adapter.jdbc.vendor.OracleExceptionSorter </exception-sorter-class-name> <metadata> <type-mapping>Oracle9i</type-mapping> </metadata> </local-tx-datasource> </datasources>
3、将Oracle的JDBC驱动程序 ojdbc14.jar 或 classes12.jar 复制到 D:\jboss420GA\server\default\lib 文件夹下。

4、在Netbeans IDE 中激活“运行环境”视图,选择“服务器”----“JBoss Application Server”,启动。启动过程中NetbeansIDE的输出窗口显示如下内容:

14:28:21,328 INFO [ConnectionFactoryBindingService] Bound ConnectionManager 'jboss.jca:service=DataSourceBinding,name=OracleDS' to JNDI name 'java:OracleDS' 14:28:21,406 INFO [TomcatDeployer] deploy, ctxPath=/jmx-console, warUrl=.../deploy/jmx-console.war/ 14:28:21,953 INFO [EARDeployer] Init J2EE application: file:/K:/J2ee/jboss-4.2.0.GA/server/default/deploy/EJB3Leaning.ear ......
注意粗体字内容,说明数据源配置文件没有问题。

5、编写Servlet测试数据源是否有效:新建Web项目,建立测试数据源的Servlet,其内容如下:
 protected void processRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); DataSource ds; try { ds = getOracleDS(); Connection conn=ds.getConnection(); Statement sta=conn.createStatement(); ResultSet rs= sta.executeQuery("select * from Employee"); while ( rs.next() ) { out.println(rs.getString(2)+"<br>"); } rs.close(); conn.close(); } catch (Exception ex) { ex.printStackTrace(); } out.close(); } private DataSource getOracleDS() throws NamingException { Context c = new InitialContext(); return (DataSource) c.lookup("java:comp/env/OracleDS"); } 

运行,调用此Servlet,页面上成功列出了 Employee 表中所有雇员的名字。

说明,数据源配置正确。

6、创建“企业应用程序”项目,在EJB模块中,利用“通过数据库创建实体类”向导,选择OracleDS数据源,创建Employee表及其关联表映射的实体类,并同时创建持久化单元。持久化单元定义文件persistence.xml 内容如下:
 <?xml version="1.0" encoding="UTF-8"?> <persistence version="1.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"> <persistence-unit name="testEJB-ejbPU" transaction-type="JTA"> <jta-data-source>OracleDS</jta-data-source> <properties/> </persistence-unit> </persistence> 

7、部署EJB:在项目名称上右键点击,但后选择“部署项目”菜单项。注意观察JBoss服务器的输出信息。发现有如下错误信息:
 15:04:55,437 INFO [PersistenceUnitDeployment] Starting persistence unit persistence.units:ear=testEJB.ear,unitName=testEJB-ejbPU 15:04:55,718 WARN [ServiceController] Problem starting service persistence.units:ear=testEJB.ear,unitName=testEJB-ejbPU javax.naming.NameNotFoundException: OracleDS not bound at org.jnp.server.NamingServer.getBinding(NamingServer.java:529) at org.jnp.server.NamingServer.getBinding(NamingServer.java:537) at org.jnp.server.NamingServer.getObject(NamingServer.java:543) at org.jnp.server.NamingServer.lookup(NamingServer.java:296) at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:625) ...... 

数据源配置没问题,但是发布EJB的时候就报数据源绑定错误。

为什么?!

这个问题困扰了我好几天,终于在 WikiJBoss 找到了答案。原来需要在数据原配置文件oracle-ds.xml中加入不使用Java上下文的选项:
 <use-java-context>false</use-java-context> 


WikiJBoss的原文摘录如下:
 <use-java-context> - A boolean indicating if the jndi-name should be prefixed with java: which causes the DataSource to only be accessible from within the jboss server vm. The default is true. Configuring a DataSource for remote usage As of jboss-4.0.0 there is support for accessing a DataSource from a remote client. The one change that is necessary for the client to be able to lookup the DataSource from JNDI is to specify use-java-context=false as shown here: <datasources> <local-tx-datasource> <jndi-name>GenericDS</jndi-name> <use-java-context>false</use-java-context> <connection-url>...</connection-url> ... This results in the DataSource being bound under the JNDI name "GenericDS" instead of the default of "java:/GenericDS" which restricts the lookup to the same VM as the jboss server. 

因此,作此修改后,前面测试数据源配置是否有效的Servlet就要做适当修改为:
 private DataSource getOracleDS() throws NamingException { Context c = new InitialContext(); return (DataSource) c.lookup("OracleDS"); } 
 搞明白这些问题后,实体部署已经没问题了。 8、设计会话Bean:采用NetbeansIDE提供的“创建实体类的会话Bean”向导,创建Emp实体类的会话Bean,生成远程接口,然后部署到JBoss服务器上,过程正常。 9、编写Servlet,通过远程接口调用会话Bean:Servlet的主要代码如下: 
 protected void processRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); EmpFacadeRemote dao=lookupEmpFacade(); List l=dao.findAll(); for (int i=0; i<l.size(); i++){ Emp e=(Emp)l.get(i); out.println(e.getEname()+"<br>"); } out.close(); } private EmpFacadeRemote lookupEmpFacade() { try { Context c = new InitialContext(); return (EmpFacadeRemote) c.lookup("java:comp/env/ejb/EmpFacade"); } catch(NamingException ne) { Logger.getLogger(getClass().getName()).log(Level.SEVERE,"exception caught" ,ne); throw new RuntimeException(ne); } } 

然后部署项目,运行项目,当Servlet被调用时,报错:
 type Exception report message description The server encountered an internal error () that prevented it from fulfilling this request. exception java.lang.RuntimeException: javax.naming.NameNotFoundException: ejb not bound com.pqf.servlet.ListEmp.lookupEmpFacade(ListEmp.java:81) com.pqf.servlet.ListEmp.processRequest(ListEmp.java:38) com.pqf.servlet.ListEmp.doPost(ListEmp.java:64) javax.servlet.http.HttpServlet.service(HttpServlet.java:710) javax.servlet.http.HttpServlet.service(HttpServlet.java:803) org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96) root cause javax.naming.NameNotFoundException: ejb not bound org.jnp.server.NamingServer.getBinding(NamingServer.java:529) org.jnp.server.NamingServer.getBinding(NamingServer.java:537) org.jnp.server.NamingServer.getObject(NamingServer.java:543) org.jnp.server.NamingServer.lookup(NamingServer.java:267) org.jnp.server.NamingServer.lookup(NamingServer.java:270) org.jnp.interfaces.NamingContext.lookup(NamingContext.java:625) org.jnp.interfaces.NamingContext.lookup(NamingContext.java:716) org.jnp.interfaces.NamingContext.lookup(NamingContext.java:587) javax.naming.InitialContext.lookup(InitialContext.java:392) com.pqf.servlet.ListEmp.lookupEmpFacade(ListEmp.java:77) com.pqf.servlet.ListEmp.processRequest(ListEmp.java:38) com.pqf.servlet.ListEmp.doPost(ListEmp.java:64) javax.servlet.http.HttpServlet.service(HttpServlet.java:710) javax.servlet.http.HttpServlet.service(HttpServlet.java:803) org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96) 

又是为何?

(完)
分享到:
评论

相关推荐

    jboss7ejb配置文件

    这两个文件通常放在EJB模块的`META-INF`目录下,当部署到JBoss AS 7或更高版本时,服务器会自动读取这些配置并据此进行EJB的部署和管理。 EJB的配置是Java EE应用开发中不可或缺的一部分,它决定了EJB组件的行为和...

    myeclpise+jboss开发EJB

    通过本文的介绍,我们深入了解了如何使用MyEclipse和JBoss进行EJB开发,从项目创建到最终部署的整个流程。掌握了这些知识,开发者可以更加高效地开发出高质量的企业级应用程序。无论是新手还是有经验的开发者,理解...

    MyEclipse+JBoss开发EJB.doc

    总的来说,MyEclipse结合JBoss提供了一个高效、便捷的EJB开发环境,使开发者能够轻松地利用EJB技术来构建企业级应用。无论是新手还是经验丰富的开发者,都可以从中受益,实现更高质量的Java EE项目开发。

    jboss-ejb3-client.jar

    jboss-ejb3-client.jar

    JBOSS+EJB3+MYSQL开发

    在本文中,我们将深入探讨如何使用JBOSS服务器与EJB3.0相结合,并结合MySQL数据库进行企业级应用开发。JBOSS是一个流行的开源Java应用服务器,它支持EJB(Enterprise JavaBeans)3.0规范,这是一个用于构建企业级...

    Eclipse整合JBoss开发EJB3.0

    ### Eclipse 整合 JBoss 开发 EJB 3.0 #### 一、EJB 3.0 简介及重要性 EJB (Enterprise JavaBeans) 是 J2EE 架构中的一个核心组件,它提供了一种用于构建分布式企业级应用的方法。自 EJB 3.0 的推出以来,其设计...

    使用Eclipse+Jboss+MySql开发EJB

    在开发EJB时,我们可能需要与数据库交互,MySql的简单性、高效性和广泛支持使其成为EJB应用的理想选择。 **开发EJB**:EJB的开发过程主要包括以下步骤: 1. **创建EJB项目**:在Eclipse中,使用JBoss Tools插件...

    jboss-ejb-api_3.1_spec.jar

    ejb在jboss下的组件基础类,包含javax.ejb.Stateless等

    使用eclipse通过jboss开发简单的ejb应用(jboss7.x & ejb3.x)

    在本文中,我们将深入探讨如何使用Eclipse IDE与JBoss应用程序服务器(版本7.x)来开发和部署一个基于EJB 3.x的简单企业级Java应用程序。EJB(Enterprise JavaBeans)是Java平台上的核心组件,它提供了一种标准的...

    jboss开发ejb3.0实例

    使用jboss开发一个ejb3.0实例视频教程,无声的,比较适合入门者

    J2Ee Jboss Ejb With Eclipse 2003.rar_Eclipse_ejb_jboss_jboss ejb

    描述中提到的“Eclipse+JBoss开发环境下必不可少的东东”,暗示了这份资料可能是开发者在使用Eclipse与JBoss集成进行EJB开发时的重要参考资料,可能包含了配置指南、步骤说明、示例代码等,帮助开发者理解如何在2003...

    Jboss下开发ejb应用之一实体bean的应用

    本篇文章将深入探讨在JBoss应用服务器上开发EJB应用,特别是实体Bean的使用。 标题:“Jboss下开发ejb应用之一实体bean的应用” 首先,理解EJB实体Bean的含义至关重要。实体Bean代表持久化的业务对象,它们与...

    精通JBoss——EJB与Web Services开发精解

    《精通JBoss——EJB与Web Services开发精解》是一本深入探讨企业级Java应用开发的专业书籍,专注于JBoss应用服务器的使用以及EJB(Enterprise JavaBeans)和Web Services的集成开发。本书旨在帮助读者全面掌握如何在...

    不同版本jboss访问EJB的方式

    自己经过实践总结出来的jboss和jboss7访问EJB的方法,经过试验证明方法无误,这么好的资源还不赶快下载!

    Jboss下开发ejb应用之一会话bean的应用

    本文将围绕“Jboss下开发ejb应用之一会话bean的应用”这一主题,深入探讨如何在Jboss应用服务器上开发和部署会话Bean,以及涉及到的相关工具和源码。 会话Bean是EJB的一种类型,它代表了业务逻辑组件,为客户端提供...

    利用Myeclipse6和jboss开发EJB3入门实例

    ### 利用Myeclipse 6与JBoss开发EJB3入门实例详解 #### 一、概述 本文将详细介绍如何使用Myeclipse 6和JBoss来开发一个EJB3入门级的应用程序。通过本教程,您将学习到EJB3的基本概念、所需开发工具的配置、以及...

    jboss-ejb3x.jar

    使用jboss-4.2.2.GA+JbossIDE for eclipse+MyElipse5.0+JDK1.5做一个EJB3.0 的例子 所需要的文件

    javax.ejb.EJB 需要的jar____jboss-ejb3x.jar

    开发ejb时总是无法用@EJB 解决办法: javax.ejb.EJB 需要的jar___jboss-ejb3x.jar

    在JBoss下配置EJB

    最后,要特别注意的是,EJB配置文件的正确性至关重要,任何错误都可能导致部署失败或运行时异常。因此,开发者应当仔细检查配置,确保所有的类路径、接口和JNDI名称都正确无误。同时,利用EJB的调试工具和日志可以...

Global site tag (gtag.js) - Google Analytics