0

我正在运行一个 Web 应用程序,它具有应用程序的前端 ( JSF, CDI) 和后端 ( EJB, Hibernate) 部分,每个部分都位于单独的WildFly 9.0.1.Final AS. 前端通过Remote EJB ClientJNDI 名称与后端通信。

一些前端代码:

@ViewScoped
@Named("ddc")
public class DynamicDatatableController implements Serializable {    
    @Produces
    @Resource(lookup = "ejb:bpm-back-ear/bpm-back-dynamicTable/DynamicTableBean!bc.bpm.dynamicTable.back.beans.remote.DynamicTableBeanRemote")
    private DynamicTableBeanRemote dtb;

    private Integer tableId;
    private DynamicTable table;

    @PostConstruct
    public void init{
      table = dtb.getTable(tableId);
    }
}

以及一些后端接口代码:

@Remote
public interface DynamicTableBeanRemote {
    List<DynamicTable> getTable(Integer tableId);
}

还有一些后端 bean 代码:

@Stateless
@LocalBean
public class DynamicTableBean implements DynamicTableBeanRemote {
    final static Logger LOGGER = LoggerFactory.getLogger(DynamicTableBean.class);
    @PersistenceContext(unitName = "bpmBeans")
    private EntityManager em;

    @Override
    public List<DynamicTable> getTableList(Integer tableId) {
        return em.find(DynamicTable.class, tableId);
    }
}

问题是,无论我做了多少请求,使用 JMeter 或刷新几个浏览器选项卡,DynamicTableBean在任何给定时间只有一个实例是活动的。每个请求都由队列中的那个 bean 实例执行。如您所知,该应用程序绝对不可用,因为它绝对是单线程 EJB 明智的。可能是什么问题呢?

4

3 回答 3

0

检查您的 jboss ejb 池配置。在 jboss 中(这适用于 eap 6.4.2 并假设同样适用于 wildfly)您可以在 domain.xml 中配置 ejb 池大小

<subsystem xmlns="urn:jboss:domain:ejb3:1.5">
    <session-bean>
        <stateless>
            <bean-instance-pool-ref pool-name="slsb-strict-max-pool"/>
        </stateless>
    </session-bean>...
    <pools>
        <bean-instance-pools>
            <strict-max-pool name="slsb-strict-max-pool" max-pool-size="20" instance-acquisition-timeout="5" instance-acquisition-timeout-unit="MINUTES"/>
        </bean-instance-pools>
    </pools>

你可以在 jboss-ejb3.xml 中引用这个池:

<?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" xmlns:r="urn:resource-adapter-binding"
    xmlns:p="urn:ejb-pool: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">
    <assembly-descriptor>
        <p:pool>
            <ejb-name>ejebId</ejb-name>
            <p:bean-instance-pool-ref>slsb-strict-max-pool</p:bean-instance-pool-ref>
        </p:pool>
    </assembly-descriptor>
</jboss:ejb-jar>
于 2015-11-19T14:36:33.560 回答
0

无状态会话 bean 有可能以比请求到达速率更快的速率完成请求。

在这种情况下,您可能会看到只有一个无状态会话 bean 能够满足所有请求。您可能想在无状态会话 bean 中注入一些延迟,看看您是否仍然只看到它的一个实例。您可以通过以下方式注入延迟,

public List<DynamicTable> getTableList(Integer tableId) {
    try {Thread.sleep(3000); } catch (InterruptedException ex) {}
    return em.find(DynamicTable.class, tableId);
}

并且还在无状态会话 bean 默认构造函数中添加一些日志语句来检查创建了多少实例。

顺便说一句,您是如何推断出只有一个无状态会话 bean 实例被创建的?通过任何日志或控制台等。

于 2016-01-13T13:31:02.187 回答
0

问题显然在于 Intellij 14 和 JRebel 客户端的过时版本,它们都在 Linux 工作站上运行。所以这里要记住的一件事是始终保持你的工具是最新的:)

于 2016-01-14T12:50:42.817 回答