GlassFish 5.0.1(含Java 8)是否支持EJB 2.1和EJB 3.1?
我安装了GlassFish和Payara,并试图用EJB 3.1 Entity和session beans部署我的.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 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实体的支持,我在JAVA 8上用EJB 3.1 Entity和session beans编译了我的应用程序,+在-> JDBC连接池-> JNDI属性下创建了连接+用JNDI属性禁用了可移植的jndi名。set server.ejb-container.property.disable-nonportable-jndi-names="true"
也许我的glassfish-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
?