GlassFish 5.0.1(Java 8)是否支持EJB 2.1和EJB 3.1?



GlassFish 5.0.1(Java 8(是否支持EJB 2.1和EJB 3.1?

我用Payara安装了GlassFish,并尝试部署我的.带有 EJB 3.1 实体和会话 bean 的 EAR 应用程序,它挂断了ServletContext.log():Initializing Spring root WebApplicationContext

我等了几个小时,什么也没。 是的,我知道,EJB 已经死了,我应该迁移到春天......我只是在寻找替代方案,可以在没有任何迁移的情况下保存我的基于 EJB 的旧应用程序。

完整的最后日志行:

...
[2020-06-11T16:22:27.773+0300] [Payara 5.201] [INFO] [AS-EJB-00054] [javax.enterprise.ejb.container] [tid: ThreadID=101 ThreadName=admin-thread-pool::admin-listener(1)] [timeMillis: 1591881747773] [levelValue: 800] [[
Portable JNDI names for EJB WulogEJB: [java:global/CCC-ear-RAYAPP-1.0.1-SNAPSHOT-payaraora/CCC-ejb-entity-in-payara-1.0.1-SNAPSHOT/WulogEJB, java:global/CCC-ear-RAYAPP-1.0.1-SNAPSHOT-payaraora/CCC-ejb-entity-in-payara-1.0.1-SNAPSHOT/WulogEJB!com.Tree.common.entityejb.WulogEntityHome]]]
[2020-06-11T16:22:27.922+0300] [Payara 5.201] [INFO] [] [javax.enterprise.web] [tid: ThreadID=101 ThreadName=admin-thread-pool::admin-listener(1)] [timeMillis: 1591881747922] [levelValue: 800] [[
WebModule[/TreeOnline-RAYAPP] ServletContext.log():No Spring WebApplicationInitializer types detected on classpath]]
[2020-06-11T16:22:28.011+0300] [Payara 5.201] [INFO] [jsf.config.listener.version] [javax.enterprise.resource.webcontainer.jsf.config] [tid: ThreadID=101 ThreadName=admin-thread-pool::admin-listener(1)] [timeMillis: 1591881748011] [levelValue: 800] [[
Initializing Mojarra |version.string| for context '/TreeOnline-RAYAPP']]
[2020-06-11T16:22:28.471+0300] [Payara 5.201] [INFO] [] [javax.enterprise.web] [tid: ThreadID=101 ThreadName=admin-thread-pool::admin-listener(1)] [timeMillis: 1591881748471] [levelValue: 800] [[
WebModule[/TreeOnline-RAYAPP] ServletContext.log():Initializing Spring root WebApplicationContext]]
  • 我制作了玻璃鱼网.xml以添加 EAR
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE glassfish-web-app PUBLIC "-//GlassFish.org//DTD GlassFish Application Server 3.1 Servlet 3.0//EN" "http://glassfish.org/dtds/glassfish-web-app_3_0-1.dtd">
<glassfish-web-app>
<security-domain>java:/TreeSecurityDomain</security-domain>
<resource-ref>
<res-ref-name>jdbc/treeDataSource</res-ref-name>
<jndi-name>treeDataSource</jndi-name>
</resource-ref>
</glassfish-web-app>

我以前使用过 Wildfly,但它在版本 9 之后删除了 EJB 实体支持。 我已经使用 EJB 3.1 实体和会话 bean 在 JAVA 8 上编译了我的应用程序。 + 在 -> JDBC 连接池下创建的连接 -> 具有 JNDI 属性 + 禁用便携式 JNDI 名称与set server.ejb-container.property.disable-nonportable-jndi-names="true"

也许我的玻璃鱼-ejb-jar.xml语法不正确?

<?xml version="1.0" encoding="UTF-8"?>
<glassfish-ejb-jar xmlns:jboss="http://www.jboss.com/xml/ns/javaee"
xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:s="urn:security:1.1"
xsi:schemaLocation="http://www.jboss.com/xml/ns/javaee http://www.jboss.org/j2ee/schema/jboss-ejb3-2_0.xsd
http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/ejb-jar_3_1.xsd"
version="3.1" impl-version="2.1">
<assembly-descriptor>
<s:security>
<ejb-name>*</ejb-name>
<s:security-domain>TreeSecurityDomain</s:security-domain>
<s:missing-method-permissions-deny-access>false</s:missing-method-permissions-deny-access>
</s:security>
<container-transaction>
<method>
<ejb-name>*</ejb-name>
<method-name>*</method-name>
</method>
<trans-attribute>Supports</trans-attribute>
</container-transaction>
</assembly-descriptor>
<enterprise-beans>
<entity>
<ejb-name>AminataEJB</ejb-name>
<resource-ref>
<res-ref-name>jdbc/treeDataSource</res-ref-name>
<jndi-name>java:treeDataSource</jndi-name>
</resource-ref>
</entity>
<entity>
<ejb-name>AmeliaEJB</ejb-name>
<resource-ref>
<res-ref-name>jdbc/treeDataSource</res-ref-name>
<jndi-name>java:treeDataSource</jndi-name>
</resource-ref>
</entity>
</enterprise-beans>
</glassfish-ejb-jar>

可能是因为描述标签吗?

xmlns:jboss="http://www.jboss.com/xml/ns/javaee"

xsi:schemaLocation="http://www.jboss.com/xml/ns/javaee http://www.jboss.org/j2ee/schema/jboss-ejb3-2_0.xsd
http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/ejb-jar_3_1.xsd"

启用了调试级别,并看到了很多:

DEBUG o.s.jndi.JndiObjectFactoryBean - Converted JNDI name [java:comp/env/TREE/treeDataSource] not found - trying original name [TREE/treeDataSource]. javax.naming.NamingException: Lookup failed for 'java:comp/env/TREE/treeDataSource' in SerialContext[myEnv={java.naming.factory.initial=com.sun.enterprise.naming.impl.SerialInitTreeFactory, java.naming.factory.state=com.sun.corba.ee.impl.presentation.rmi.JNDIStateFactoryImpl, java.naming.factory.url.pkgs=com.sun.enterprise.naming} [Root exception is javax.naming.NameNotFoundException: No object bound to name java:comp/env/TREE/treeDataSource]

这是否意味着我需要将所有 JNDI 绑定从java:treeDataSource编辑为java:comp/env/TREE/treeDataSource

最新更新