我想,我误解了在war包中打包ejb bean的规则。
目标:我想在war包中使用ejb bean。
场景:我的战争中有一些豆子:
@Stateless
public class RegistrationServiceBean {
@PersistenceContext(unitName = "Utopia")
EntityManager em;
public RegistrationServiceBean() {}
@Schedule(hour = "*", minute = "*", second = "*/15")
public void baseRegistration() {
System.out.println("call from ejb!!");
}
public void saveTempPartner(OasysPartnerTempEntity part) {
em.persist(part);
em.flush();
}
}
它成功部署到 glassfish 服务器(ogs 3.0.1):
[#|2010-07-02T16:53:59.728+0300|INFO|oracle-glassfish3.0.1|javax.enterprise.system.container.ejb.com.sun.ejb.containers|_ThreadID=36;_ThreadName=Thread-1 ;|EJB RegistrationServiceBean 的可移植 JNDI 名称:[java:global/oasys/hydra/RegistrationServiceBean!ua.co.oasys.hydra.beans.RegistrationServiceBean, java:global/oasys/hydra/RegistrationServiceBean]|#]
但是当调度程序启动时,我得到:
[#|2010-07-02T16:54:20.004+0300|警告|oracle-glassfish3.0.1|javax.enterprise.system.container.ejb.com.sun.ejb.containers|_ThreadID=38;_ThreadName=Thread-1 ;|在调用 EJB RegistrationServiceBean 方法时发生系统异常 public void ua.co.oasys.hydra.beans.RegistrationServiceBean.baseRegistration() javax.ejb.EJBException: javax.ejb.EJBException: javax.ejb.CreateException: 不能在 com.sun.ejb.containers.StatelessSessionContainer._getContext(StatelessSessionContainer.java:448) 在 com.sun.ejb.containers.BaseContainer.getContext(BaseContainer.java:2467) 在 com.sun.ejb.containers 创建无状态 EJB。 BaseContainer.preInvoke(BaseContainer.java:1860) 在 com.sun.ejb.containers.BaseContainer.callEJBTimeout(BaseContainer.java:3962) 在 com.sun.ejb.containers.EJBTimerService。com.sun.ejb.containers.EJBTimerService.access$100(EJBTimerService.java:98) 上的 deliverTimeout(EJBTimerService.java:1667) com.sun.ejb.containers.EJBTimerService$TaskExpiredWork.run(EJBTimerService.java:2485) java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441) 在 java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303) 在 java.util.concurrent.FutureTask.run(FutureTask. java:138) 在 java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) 在 java.lang.Thread.run (Thread.java:619) 原因:javax.ejb.EJBException:javax.ejb.CreateException:无法在 com.sun.ejb.containers.StatelessSessionContainer$SessionContextFactory 创建无状态 EJB。在 com.sun.ejb.containers.StatelessSessionContainer._getContext(StatelessSessionContainer.java:443) 处创建 (StatelessSessionContainer.java:720) ... 12 更多原因:javax.ejb.CreateException: 无法在 com.sun.ejb.containers.StatelessSessionContainer.createStatelessEJB(StatelessSessionContainer.java:528) 在 com.sun.ejb.containers.StatelessSessionContainer.access 创建无状态 EJB $000(StatelessSessionContainer.java:90) at com.sun.ejb.containers.StatelessSessionContainer$SessionContextFactory.create(StatelessSessionContainer.java:718) ... 14 更多原因:java.util.concurrent.ConcurrentHashMap 的 java.lang.NullPointerException .get(ConcurrentHashMap.java:768) 在 org.jboss.weld.manager.BeanManagerImpl。getBean(BeanManagerImpl.java:1171) at org.jboss.weld.manager.BeanManagerImpl.getBean(BeanManagerImpl.java:132) at org.glassfish.weld.services.JCDIServiceImpl._createJCDIInjectionContext(JCDIServiceImpl.java:145) at org.glassfish .weld.services.JCDIServiceImpl.createJCDIInjectionContext(JCDIServiceImpl.java:122) 在 com.sun.ejb.containers.BaseContainer.createEjbInstanceAndContext(BaseContainer.java:1616) 在 com.sun.ejb.containers.StatelessSessionContainer.createStatelessEJB(StatelessSessionContainer.java :469) ... 还有 16 个 |#]java:122) 在 com.sun.ejb.containers.BaseContainer.createEjbInstanceAndContext(BaseContainer.java:1616) 在 com.sun.ejb.containers.StatelessSessionContainer.createStatelessEJB(StatelessSessionContainer.java:469) ... 16 更多 |#]java:122) 在 com.sun.ejb.containers.BaseContainer.createEjbInstanceAndContext(BaseContainer.java:1616) 在 com.sun.ejb.containers.StatelessSessionContainer.createStatelessEJB(StatelessSessionContainer.java:469) ... 16 更多 |#]
所有应用程序都打包在 ear 中,里面有 war,如果我在 ejb-jar 中部署 ejb 效果很好,但这不是我想要的。
删除焊接依赖项后,部署期间出现异常:
com.sun.enterprise.admin.cli.CommandException:远程失败:加载应用程序时出现异常:org.glassfish.deployment.common.DeploymentException:由 java.lang.NoClassDefFoundError:ua/co/oasys/hydra/beans/RegistrationServiceBean
它类似于 glassfish bug,但我不确定。
更新:web.xml:
<?xml version="1.0" encoding="UTF-8"?> <web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
<display-name>CO UA Partners</display-name>
<description>CO UA Partners Site</description>
<context-param>
<param-name>javax.faces.PROJECT_STAGE</param-name>
<param-value>Development</param-value>
</context-param>
<context-param>
<param-name>javax.faces.DEFAULT_SUFFIX</param-name>
<param-value>.xhtml</param-value>
</context-param>
<context-param>
<param-name>javax.faces.STATE_SAVING_METHOD</param-name>
<param-value>server</param-value>
</context-param>
<!--Prime Faces-->
<context-param>
<param-name>primefaces.skin</param-name>
<param-value>sam</param-value>
</context-param>
<!--Prime Faces end-->
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>/faces/*</url-pattern>
</servlet-mapping>
<context-param>
<param-name>javax.faces.FACELETS_SKIP_COMMENTS</param-name>
<param-value>true</param-value>
</context-param>
<session-config>
<session-timeout>
30
</session-timeout>
</session-config>
<welcome-file-list>
<welcome-file>faces/index.xhtml</welcome-file>
</welcome-file-list>
<security-role>
<role-name>manager</role-name>
</security-role>
<security-constraint>
<web-resource-collection>
<web-resource-name>Manager Pages</web-resource-name>
<url-pattern>/faces/partner/manager/*</url-pattern>
<url-pattern>/partner/manager/*</url-pattern>
<url-pattern>/partner/*</url-pattern>
<url-pattern>/faces/partner/*</url-pattern>
</web-resource-collection>
<auth-constraint>
<role-name>manager</role-name>
</auth-constraint>
</security-constraint>
<security-role>
<role-name>admin</role-name>
</security-role>
<security-constraint>
<web-resource-collection>
<web-resource-name>Admin Pages</web-resource-name>
<url-pattern>/faces/partner/admin/*</url-pattern>
<url-pattern>/partner/admin/*</url-pattern>
<url-pattern>/partner/*</url-pattern>
<url-pattern>/faces/partner/*</url-pattern>
</web-resource-collection>
<auth-constraint>
<role-name>admin</role-name>
</auth-constraint>
</security-constraint>
<!--roots-->
<security-role>
<role-name>rmanager</role-name>
</security-role>
<security-role>
<role-name>radmin</role-name>
</security-role>
<security-role>
<role-name>bookkeper</role-name>
</security-role>
<login-config>
<auth-method>FORM</auth-method>
<realm-name>oasysRealm</realm-name>
<form-login-config>
<form-login-page>/faces/login.xhtml</form-login-page>
<form-error-page>/faces/loginError.xhtml</form-error-page>
</form-login-config>
</login-config>
</web-app>
NoClassDefFoundError 异常:
[#|2010-07-04T16:16:26.401+0300|SEVERE|oracle-glassfish3.0.1|javax.enterprise.system.core.com.sun.enterprise.v3.server|_ThreadID=25;_ThreadName=Thread-1 ;|加载应用程序时出现异常 org.glassfish.deployment.common.DeploymentException: by java.lang.NoClassDefFoundError: ua/co/oasys/hydra/RegistrationServiceBea at org.glassfish.weld.WeldDeployer.event(WeldDeployer.java:167)在 org.glassfish.kernel.event.EventsImpl.send(EventsImpl.java:125) 在 org.glassfish.internal.data.ApplicationInfo.load(ApplicationInfo.java:224) 在 com.sun.enterprise.v3.server.ApplicationLifecycle .deploy(ApplicationLifecycle.java:338) at com.sun.enterprise.v3.server.ApplicationLifecycle.deploy(ApplicationLifecycle.java:183) at org.glassfish.deployment.admin.DeployCommand.execute(DeployCommand.java:272) at com.sun.enterprise。v3.admin.CommandRunnerImpl$1.execute(CommandRunnerImpl.java:305) 在 com.sun.enterprise.v3.admin.CommandRunnerImpl.doCommand(CommandRunnerImpl.java:320) 在 com.sun.enterprise.v3.admin.CommandRunnerImpl.doCommand (CommandRunnerImpl.java:1176) at com.sun.enterprise.v3.admin.CommandRunnerImpl.access$900(CommandRunnerImpl.java:83) at com.sun.enterprise.v3.admin.CommandRunnerImpl$ExecutionContext.execute(CommandRunnerImpl.java: 1235)在com.sun.enterprise.v3.admin.AdminAdapter.doCommand(AdminAdapter.java:365)在com.sun .enterprise.v3.admin.AdminAdapter.service(AdminAdapter.java:204) 在 com.sun.grizzly.tcp.http11.GrizzlyAdapter.service(GrizzlyAdapter.java:166) 在 com.sun.enterprise.v3.server。HK2Dispatcher.dispath(HK2Dispatcher.java:100) 在 com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:245) 在 com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java: 791) 在 com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:693) 在 com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:954) 在 com.sun.grizzly.http.DefaultProtocolFilter .execute(DefaultProtocolFilter.java:170) 在 com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:135) 在 com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:102) 在 com.sun.grizzly。 com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:76) 上的 DefaultProtocolChain.execute(DefaultProtocolChain.java:88)。ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:53) 在 com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:57) 在 com.sun.grizzly.ContextTask.run(ContextTask.java:69) 在 com.sun.grizzly .util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:330) 在 com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:309) 在 java.lang.Thread.run(Thread.java:619 ) 引起:java.lang.RuntimeException:由 java.lang.NoClassDefFoundError: ua/co/oasys/hydra/RegistrationServiceBea 在 javassist.util.proxy.ProxyFactory.createClass3(ProxyFactory.java:344) 在 javassist.util.proxy。 org.jboss.weld.util.Proxies 的 javassist.util.proxy.ProxyFactory.createClass(ProxyFactory.java:273) 的 ProxyFactory.createClass2(ProxyFactory.java:314)。createProxyClass(Proxies.java:187) at org.jboss.weld.util.Proxies.createProxyClass(Proxies.java:168) at org.jboss.weld.bean.SessionBean.initProxyClass(SessionBean.java:221) at org.jboss .weld.bean.SessionBean.initialize(SessionBean.java:143) 在 org.jboss.weld.bootstrap.AbstractBeanDeployer.deploy(AbstractBeanDeployer.java:110) 在 org.jboss.weld.bootstrap.BeanDeployment.deployBeans(BeanDeployment.java :151) at org.jboss.weld.bootstrap.WeldBootstrap.deployBeans(WeldBootstrap.java:377) at org.glassfish.weld.WeldDeployer.event(WeldDeployer.java:165) ... 30 更多原因:javassist.CannotCompileException : 通过 java.lang.NoClassDefFoundError: ua/co/oasys/hydra/RegistrationServiceBea 在 javassist.util.proxy.FactoryHelper.toClass(FactoryHelper.java:169) 在 javassist.util.proxy.ProxyFactory。createClass3(ProxyFactory.java:339) ... 40 更多原因:java.lang.NoClassDefFoundError: ua/co/oasys/hydra/RegistrationServiceBea at java.lang.ClassLoader.defineClass1(Native Method) at java.lang.ClassLoader。在 sun.reflect.GeneratedMethodAccessor196.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 的 java.lang.ClassLoader.defineClass(ClassLoader.java:616) 的 defineClassCond(ClassLoader.java:632)在 java.lang.reflect.Method.invoke(Method.java:597) 在 javassist.util.proxy.FactoryHelper.toClass2(FactoryHelper.java:181) 在 javassist.util.proxy.FactoryHelper.toClass(FactoryHelper.java:163 ) ... 41 更多原因:com.sun.enterprise.loader 上的 java.lang.ClassNotFoundException: ua.co.oasys.hydra.RegistrationServiceBea。ASURLClassLoader.findClassData(ASURLClassLoader.java:713) 在 com.sun.enterprise.loader.ASURLClassLoader.findClass(ASURLClassLoader.java:626) 在 java.lang.ClassLoader.loadClass(ClassLoader.java:307) 在 java.lang.ClassLoader .loadClass(ClassLoader.java:248) ... 49 更多 |#]
更新 2:
如果删除/重命名 beans.xml 文件 ejbs 部署成功。
更新 3:
osys.ear
jar xfv ~/Sites/workspace/Intellij_IDEA_9/Oasys/Oasys-ear/target/oasys.ear 创建:META-INF/ 膨胀:META-INF/MANIFEST.MF 创建:lib/ 膨胀:fenix.jar 膨胀:hydra.war膨胀:javax.inject-1.jar 膨胀:jboss-interceptor-api-1.1-CR1.jar 膨胀:jsr250-api-1.0.jar 膨胀:lib/cdi-api-1.0-CR4.jar 膨胀:lib/eclipselink- 2.1.0-SNAPSHOT.jar 膨胀:lib/javax.persistence-2.0.0.jar 膨胀:lib/slf4j-api-1.6.0.jar 膨胀:lib/slf4j-jdk14-1.6.0.jar 膨胀:lib/ utopia.jar 膨胀:lib/weld-logger-1.0.0-CR2.jar 膨胀:META-INF/application.xml
创建:META-INF/maven/ 创建:META-INF/maven/ua.co.oasys/ 创建:META-INF/maven/ua.co.oasys/oasys-ear/ 膨胀:META-INF/maven/ua。 co.oasys/oasys-ear/pom.xml 膨胀:META-INF/maven/ua.co.oasys/oasys-ear/pom.properties
九头蛇战争
jar xfv ~/Sites/workspace/Intellij_IDEA_9/Oasys/Hydra/target/hydra.war 创建:META-INF/ 膨胀:META-INF/MANIFEST.MF 创建:合作伙伴/ 创建:合作伙伴/管理员/
创建:合作伙伴/经理/创建:resources/ 创建:resources/css/
创建:resources/css/sam/ 创建:resources/css/sam/images/ 创建:resources/layout/ 创建:resources/security/ 创建:root/
创建:root/admin/创建:root/bookkeeper/ 创建:root/manager/ 创建:WEB-INF/
创建:WEB-INF/classes/ 创建:WEB-INF/classes/ua/ 创建:WEB-INF/classes/ua/co/ 创建: WEB-INF/classes/ua/co/oasys/
创建:WEB-INF/classes/ua/co/oasys/hydra/
创建:WEB-INF/classes/ua/co/oasys/hydra/common/ 创建:WEB-INF/classes/ua/co/oasys/hydra/i18n/ 创建:WEB-INF/classes/ua/co/oasys/ hydra/mb/ 创建:WEB-INF/classes/ua/co/oasys/hydra/mb/registration/ 创建:WEB-INF/classes/ua/co/oasys/hydra/mb/security/ 创建:WEB-INF/ classes/ua/co/oasys/hydra/mb/ua/ 创建:WEB-INF/classes/ua/co/oasys/hydra/mb/ua/co/ 创建:WEB-INF/classes/ua/co/oasys/ hydra/mb/ua/co/oasys/ 创建:WEB-INF/classes/ua/co/oasys/hydra/mb/ua/co/oasys/hydra/ 创建:WEB-INF/classes/ua/co/oasys/ hydra/mb/ua/co/oasys/hydra/i18n/ 创建:WEB-INF/lib/ 膨胀:html5.html 膨胀:index.xhtml 膨胀:login.xhtml 膨胀:loginError.xhtml 膨胀:合作伙伴/管理员/管理员。 xhtml 膨胀:partner/manager/manager.xhtml 膨胀:partner/partner.xhtml 膨胀:register.xhtml 膨胀:resources/css/cssLayout.css 膨胀:resources/css/default.css 膨胀:resources/css/master.css 膨胀:resources/css/sam/images/sprite.png 膨胀:resources/css/sam /images/ui-bg_flat_0_aaaaaa_40x100.png 膨胀:resources/css/sam/images/ui-bg_flat_75_ffffff_40x100.png 膨胀:resources/css/sam/images/ui-bg_glass_55_fbf9ee_1x400.png 膨胀:resources/css/sam/images/ui- bg_glass_65_ffffff_1x400.png 膨胀:resources/css/sam/images/ui-bg_glass_75_dadada_1x400.png 膨胀:resources/css/sam/images/ui-bg_glass_75_e6e6e6_1x400.png 膨胀:resources/css/sam/images/ui-bg_glass_905_fef1ec_1x资源/css/sam/images/ui-bg_highlight-soft_75_cccccc_1x100.png 膨胀:资源/css/sam/images/ui-icons_222222_256x240.png 膨胀:resources/css/sam/images/ui-icons_2e83ff_256x240.png 膨胀:resources/css/sam/images/ui-icons_454545_256x240.png 膨胀:resources/css/sam/images/ui-icons_888888_256x240.png 膨胀:resources/css/sam /images/ui-icons_cd0a0a_256x240.png 膨胀:resources/css/sam/skin.css 膨胀:resources/layout/doublevontent.xhtml 膨胀:resources/layout/header.xhtml 膨胀:resources/layout/masterLayout.xhtml 膨胀:resources/ prime-themes/vader/skin.css 膨胀:resources/security/loginPanel.xhtml 膨胀:root/admin/radmin.xhtml 膨胀:root/bookkeeper/rbookkeeper.xhtml 膨胀:root/manager/rmanager.xhtml 膨胀:WEB-INF /beans.xml 膨胀:WEB-INF/classes/ua/co/oasys/hydra/common/SkinBean.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/i18n/messages.properties 膨胀:WEB-INF/classes/ua/co/oasys/hydra/i18n/messages_en_US.properties 膨胀:WEB-INF/classes/ua/co/oasys/hydra/i18n/messages_ru_RU.properties 膨胀:WEB-INF/classes/ua/ co/oasys/hydra/i18n/messages_uk_UA.properties 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/CustomCharacterEncodingFilter.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/ Messenger.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/registration/TempReg.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/security/LogOutActionListener.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/security/LogoutServlet.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/security/RulesBean.class 膨胀:WEB-INF /classes/ua/co/oasys/hydra/mb/security/SecurityBacking.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/security/UserBean。类膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/security/UserManager.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/ua/co/oasys/hydra/ i18n/Messages.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/ua/co/oasys/hydra/i18n/Utf8ResourceBundle$1.class 膨胀:WEB-INF/classes/ua/co/oasys /hydra/mb/ua/co/oasys/hydra/i18n/Utf8ResourceBundle$Utf8PropertyResourceBundle.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/ua/co/oasys/hydra/i18n/Utf8ResourceBundle。类膨胀:WEB-INF/classes/ua/co/oasys/hydra/RegistrationServiceBea.class 膨胀:WEB-INF/faces-config.xmlWEB-INF/classes/ua/co/oasys/hydra/mb/ua/co/oasys/hydra/i18n/Utf8ResourceBundle$1.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/ua/ co/oasys/hydra/i18n/Utf8ResourceBundle$Utf8PropertyResourceBundle.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/ua/co/oasys/hydra/i18n/Utf8ResourceBundle.class 膨胀:WEB-INF/ classes/ua/co/oasys/hydra/RegistrationServiceBea.class 膨胀:WEB-INF/faces-config.xmlWEB-INF/classes/ua/co/oasys/hydra/mb/ua/co/oasys/hydra/i18n/Utf8ResourceBundle$1.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/ua/ co/oasys/hydra/i18n/Utf8ResourceBundle$Utf8PropertyResourceBundle.class 膨胀:WEB-INF/classes/ua/co/oasys/hydra/mb/ua/co/oasys/hydra/i18n/Utf8ResourceBundle.class 膨胀:WEB-INF/ classes/ua/co/oasys/hydra/RegistrationServiceBea.class 膨胀:WEB-INF/faces-config.xml膨胀:WEB-INF/lib/primefaces-2.1.RC1-SNAPSHOT.jar 膨胀:WEB-INF/sun-web.xml 膨胀:WEB-INF/web.xml 创建:META-INF/maven/ 创建:META-INF /maven/ua.co.oasys/ 创建:META-INF/maven/ua.co.oasys/hydra/ 膨胀:META-INF/maven/ua.co.oasys/hydra/pom.xml 膨胀:META-INF/ maven/ua.co.oasys/hydra/pom.properties
- Q1:使用war中打包的ejb bean是否可以接受(规范是这样的)?
- Q2:我应该通过 ejb-jar.xml 描述一些配置吗?
- Q3:问题的原因可能是什么?