会话bean的JNDI查找名称使用以下语法:
ejb:<appName>/<moduleName>/<distinctName>/<beanName>!<viewClassName>?stateful
*<appName>:如果会话bean的JAR文件已部署在企业归档(EAR)中,则appName是相应EAR的名称。默认情况下,EAR的名称是没有.ear后缀的文件名。应用程序名称可以在其application.xml文件中被覆盖。如果会话bean未部署在EAR中,则将appName留空。
*<moduleName>:moduleName是部署会话bean的JAR文件的名称。 JAR文件的默认名称是其没有.jar后缀的文件名。可以在JAR的ejb-jar.xml文件中覆盖模块名称。
*<distinctName>:JBoss EAP允许每个部署指定一个可选的不同名称。如果部署没有不同的名称,那么将distinctName留空。
*<beanName>:beanName是要调用的会话bean的简单类名。
*<viewClassName>:viewClassName是远程接口的完全限定类名。这包括接口的包名称。
*?stateful:当JNDI名称引用有状态会话bean时,需要使用?stateful后缀。它不包括在其他bean类型中。
例如,如果我们部署了一个有状态beanorg.jboss.example.HelloBean的hello.jar,它暴露了远程接口org.jboss.example.Hello,则JNDI查找名称将是:
ejb:/hello/HelloBean!org.jboss.example.Hello?stateful"
本节将介绍JBoss如何实现@EJB和@Resource。请注意,XML始终覆盖注释,但适用相同的规则。
@EJB注释规
*@EJB注释也有一个mappedName()属性。该规范将此作为供应商特定的元数据,但JBoss将mappedName()识别为正在引用的EJB的全局JNDI名称。如果指定了mappedName(),则所有其他属性都将被忽略,并且此全局JNDI名称用于绑定。
*如果指定@EJB,不定义属性:@EJB
ProcessPayment myEjbref;
那么以下规则适用:
*引用bean的EJB jar使用@EJB注入中使用的接口来搜索EJB。如果有多个EJB发布相同的业务接口,则抛出异常。如果该接口只有一个bean,那么使用该bean。
*搜索发布该界面的EJB的EAR。如果有重复,则抛出异常。否则返回匹配的bean。
在JBoss运行时全局搜索该接口的EJB。再次,如果发现重复,则抛出异常。
@ EJB.beanName()对应于<ejb-link>。如果beanName()被定义,则使用与@EJB相同的算法,除了使用beanName()作为搜索中的关键字之外,没有定义属性。此规则的一个例外是如果您使用ejb-link#语法:它允许您在引用的EJB所在的EAR中放置一个相对路径。有关更多详细信息,请参阅EJB 3.2规范。
包括从远程客户端调用会话bean的Maven项目需要JBoss EAP Maven存储库中的以下依赖关系。
注意
artifactId版本可能会更改。有关最新版本,请参阅JBoss EAP Maven存储库。
表A.1 远程EJB客户端的Maven依赖关系
GroupID
ArtifactID
org.jboss.bom
jboss-eap-javaee7
org.jboss.spec.javax.transaction
jboss-transaction-api_1.2_spec
org.jboss.spec.javax.ejb
jboss-ejb-api_3.2_spec
org.jboss.eap
wildfly-ejb-client-bom
jboss-eap-javaee7“物料清单”(BOM)包装了JBoss EAP应用程序通常需要的许多工件的正确版本。 BOM依赖项在导入范围的pom.xml的<dependencyManagement>部分中指定。
示例POM文件<dependencyManagement>部分
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.jboss.bom</groupId>
<artifactId>jboss-eap-javaee7</artifactId>
<version>${version.jboss.bom.eap}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
其余依赖项在具有运行时间的pom.xml文件的<dependencies>部分中指定。
示例POM文件<依赖关系>部分
<dependencies>
<!-- Include the EJB client JARs -->
<dependency>
<groupId>org.jboss.eap</groupId>
<artifactId>wildfly-ejb-client-bom</artifactId>
<type>pom</type>
<scope>compile</scope>
</dependency>
<!-- Include any additional dependencies required by the application
...
-->
</dependencies>
JBoss EAP附带的ejb远程快速启动提供了远程EJB客户端应用程序的完整工作示例。有关远程会话bean调用的依赖关系配置的完整示例,请参阅位于该快速启动的根目录中的client /pom.xml文件。
jboss-ejb3.xml是可以在EJB JAR或WAR归档中使用的自定义部署描述符。在EJB JAR存档中,它必须位于META-INF /目录中。在WAR档案中,它必须位于WEB-INF /目录中。
该格式与ejb-jar.xml类似,使用一些相同的命名空间并提供一些其他命名空间。 jboss-ejb3.xml的内容与ejb-jar.xml的内容合并,jboss-ejb3.xml项目优先。
本文档仅涵盖了jboss-ejb3.xml使用的其他非标准命名空间。有关标准命名空间的文档,请参阅http://java.sun.com/xml/ns/javaee/。
根命名空间是http://www.jboss.com/xml/ns/javaee。
装配描述符命名空间
以下命名空间都可以在<assembly-descriptor>元素中使用。它们可以用于将其配置应用于单个bean,或者通过使用*作为ejb名称将其部署到部署中的所有bean。
聚类命名空间:urn:clustering:1.0
xmlns:c="urn:clustering:1.0"
这允许您将EJB标记为聚簇。它是相当于@ org.jboss.ejb3.annotation.Clustered的部署描述符。
<c:clustering>
<ejb-name>DDBasedClusteredSFSB</ejb-name>
<c:clustered>true</c:clustered>
</c:clustering>
安全命名空间(urn:security)
xmlns:s="urn:security"
这允许您为EJB设置安全域和运行为主体。
<s:security>
<ejb-name>*</ejb-name>
<s:security-domain>myDomain</s:security-domain>
<s:run-as-principal>myPrincipal</s:run-as-principal>
</s:security>
资源适配器命名空间:urn:resource-adapter-binding
xmlns:r="urn:resource-adapter-binding"
这允许您设置消息驱动Bean的资源适配器。
<r:resource-adapter-binding>
<ejb-name>*</ejb-name>
<r:resource-adapter-name>myResourceAdapter</r:resource-adapter-name>
</r:resource-adapter-binding>
IIOP命名空间:urn:iiop
xmlns:u="urn:iiop"
IIOP命名空间是配置IIOP设置的地方。
池命名空间:urn:ejb-pool:1.0xmlns:p="urn:ejb-pool:1.0"
这允许您选择包含的无状态会话bean或消息驱动Bean使用的池。池在服务器配置中定义。
<p:pool>
<ejb-name>*</ejb-name>
<p:bean-instance-pool-ref>my-pool</p:bean-instance-pool-ref>
</p:pool>
缓存命名空间:urn:ejb-cache:1.0
xmlns:c="urn:ejb-cache:1.0"
这允许您选择包含的有状态会话bean使用的缓存。缓存在服务器配置中定义。
<c:cache>
<ejb-name>*</ejb-name>
<c:cache-ref>my-cache</c:cache-ref>
</c:cache>
<?xml version="1.1" encoding="UTF-8"?>
<jboss: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:c="urn:clustering:1.0"
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.0">
<enterprise-beans>
<message-driven>
<ejb-name>ReplyingMDB</ejb-name>
<ejb-class>org.jboss.as.test.integration.ejb.mdb.messagedestination.ReplyingMDB</ejb-class>
<activation-config>
<activation-config-property>
<activation-config-property-name>destination</activation-config-property-name>
<activation-config-property-value>java:jboss/mdbtest/messageDestinationQueue
</activation-config-property-value>
</activation-config-property>
</activation-config>
</message-driven>
</enterprise-beans>
<assembly-descriptor>
<c:clustering>
<ejb-name>DDBasedClusteredSFSB</ejb-name>
<c:clustered>true</c:clustered>
</c:clustering>
</assembly-descriptor>
</jboss:ejb-jar>
您可以使用管理控制台或管理CLI创建EJB线程池。
使用管理控制台配置EJB线程池
1.登录到管理控制台。
2.单击配置选项卡。展开Subsystems菜单。
3.选择EJB 3,然后单击查看。
4.选择容器选项卡,然后单击线程池。
5.单击添加。出现创建THREAD-POOL对话框。
6.指定所需的详细信息,名称和最大线程值。
7.单击保存。
使用管理CLI配置EJB线程池
使用以下语法的add操作:/subsystem=ejb3/thread-pool=THREADPOOLNAME:add(max-threads=MAXSIZE)
*将THREADPOOLNAME替换为线程池所需的名称。
*以最大大小的线程池替换MAXSIZE。
使用read-resource操作来确认bean池的创建:
/subsystem=ejb3/thread-pool=THREADPOOLNAME:read-resource
要重新配置ejb3子系统中的所有服务以使用新的线程池,请使用以下命令:
/subsystem=ejb3/thread-pool=bigger:add(max-threads=100)
/subsystem=ejb3/service=async:write-attribute(name=thread-pool-name, value="bigger")
/subsystem=ejb3/service=remote:write-attribute(name=thread-pool-name, value="bigger")
/subsystem=ejb3/service=timer-service:write-attribute(name=thread-pool-name, value="bigger")
reload
XML配置示例:
<subsystem xmlns="urn:jboss:domain:ejb3:4.0">
...
<async thread-pool-name="bigger"/>
...
<timer-service thread-pool-name="bigger" default-data-store="default-file-store">
...
<remote connector-ref="http-remoting-connector" thread-pool-name="bigger"/>
...
<thread-pools>
<thread-pool name="default">
<max-threads count="10"/>
<keepalive-time time="100" unit="milliseconds"/>
</thread-pool>
<thread-pool name="bigger">
<max-threads count="100"/>
</thread-pool>
</thread-pools>
...
注意
不应该使用keepalive时间,因为它没有效果。
原文地址: