- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
假设您有一个带有 EJB3/JPA 和 JSF 堆栈的 Web 应用程序。据我所知,您可以使用不同的托管 bean 设计您的屏幕,例如,让我们假设一个 HeaderBean
和一个 ListingBean
。由于 EJB3 AFAIK 中没有 OSIF 模式,以下伪代码中执行了多少个不同的事务:
@ManagedBean
class HeaderBean {
@PreConstruct
load(){
// enters transaction boundary, probably will create a new tx
headerInfo = ejb.loadFromDb();
}
}
@ManagedBean
class ListingBean{
@PreConstruct()
list(){
// enters transaction boundary, probably will NOT join the headerBean tx
List<Data> listing = eao.loadFromDb(0, 20);
}
}
据我所知,当您离开 EJB 层时,所有事务都已提交;因此,如果我从表示层调用两个不同的 SLSB,它将在两个不同的事务中运行(并且可能打破我的 ACID 期望,对吧?)。
澄清:我知道 EJB3 事务行为,例如 required、never、requires_new
等。我的问题更多是关于 View-First
(例如 JSF)如何促进这种屏幕数据可能跨越多个事务并因此可能不准确的设计。
与短交易但数据不正确相比,我更喜欢较长的交易但数据正确。我想知道 jBoss Seam 等新框架是否以某种方式促进了这一点或提供了替代设计(例如:Open-Session-In-View 模式)。
最佳答案
有一些选项可以控制 EJB 的事务行为。通常他们有一个“需要一个事务”设置,所以如果一个 bean 被调用时有一个事务,那么这个 bean 的工作就包含在已经建立的事务中,否则一个事务将在 bean 返回时开始并完成。
在您的代码中,在进入 EJB 时没有任何事务,因此正如您在从 EJB 返回时所说的那样,任何事务都已解决。
虽然这看起来可能存在问题,因为您可能会得到不一致的数据 View ,但我认为这种行为是可取的。我们希望在事务中花费的时间很短 - 否则数据库锁会持有很长时间,因此并发性会受到影响。
EJB 层应该被视为提供原子服务并相应地设计和使用。我不知道我是否正确地阅读了您的代码,但是对 Header 和 Body 使用单独的访问方法可能不是最好的设计。如果您需要 header 和正文之间的一致性,则在一次调用中获取所有数据可能更可取,并且实际上在单个数据库交互中更有效地完成。
--添加---您已经在您的问题中澄清,您确实关心屏幕不同部分之间的一致性,如果使用简单的 JSF 技术编码将使用单独的事务。
在我看来,当这种不一致极不可能或不可避免时,默认的 JSF 方法是合适的。例子:1).不太可能:查询历史数据,昨天的交易总额和昨天的交易列表。在历史无法更改的系统中,此类单独的查询将是一致的。2).不可避免:摘要来自一个系统,细节来自不同的系统,两个系统之间没有事务协调,我们无法保证一致性。我们只需要向用户显示这两个 View 可能略微不一致的迹象。
在你真正想要一致性的地方使用不同的方法,在一个请求中获取所有数据并保存它(比如在 session 或请求中)然后在两个 View 中使用它 - 如果你关心 View 不应该获取自己的数据关于这些事情。
我认为您会发现尝试使用事务来保持一致性会增加相当大的复杂性并影响吞吐量。跨 View 协调事务的问题在于没有简单的“所有者”,如果您重构页面,您将需要更改逻辑
关于java - 典型的 EJB3/JPA/JSF 中的事务范围是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8617795/
我需要审核 ejb bean 的调用。说审计我的意思是将当前登录的用户、方法名称、附加描述等信息写入数据库。我决定使用 CDI 装饰器来做到这一点: @Decorator public class A
当我使用 EJB 3.0 部署 Web 应用程序时,我看到了以下警告: WARNING: jar 'E:\mws\MCDS\portal\portal-web\target\portal-web-1.
我正在学习 EJB,当尝试使用 junit 测试它时,出现以下错误 cd.espoirmur.Ejb.InterfaceEjbLocal_80488159 Jun 03, 2016 10:33:58
是否可以在另一个 EJB 中使用 @EJB?我现在正在尝试这样做,但我的 EJB 最终为空。我将在示例中概述我的问题。 @Stateless @LocalBean @Local(LoginServic
我已通读 article试图理解为什么要在客户端和实体 bean 之间有一个 session bean。是不是因为让客户端直接访问实体bean,就让客户端对数据库一清二楚了? 因此,通过使用中间人(
我们正在尝试在具有两个节点的以域模式运行的 Wildfly 中查找远程 EJB。 设置是这样的: Wildfly 节点 1: 模块 A:EJB 客户端 模块 B:远程 EJB Wildfly 节点 2
我正在使用 Jboss 7,并且有两个单独的部署,它们都包含单例 EJB。 我需要一个 EJB 才能访问另一个 EJB 并能够调用其方法,但是,当应用程序服务器启动并尝试部署它们时,它似乎无法保证哪个
可能最好的方法是手动完成。但是在大型项目中,您需要一些工具来帮助您。正是这个想法促使我搜索了一个工具。 是否有任何 EJB 迁移工具可用于将 EJB 2.0 迁移到 3.x。 最佳答案 它的开发时间很
I am migrating Ejb 2.1 to Ejb 3.1. I changed Java Version from 1.6 to 1.8, and Ejb Version from 2.1
我已经使用 @ActivationConfigProperty 配置了消息目标类型、名称等。在 EJB 3.0 中,但我想配置 MDB使用部署描述符 ( ejb-jar.xml ),就像在 EJB 2
假设我有两个 EJB jar:A.jar 和 B.jar。我可以使用 CDI 将不是 EJB 的实用程序类 Autil 注入(inject) A.jar 中的 POJO 到 B.jar 中的 EJB
我有一个需要配置不同的现有项目。这需要在没有重大代码更改的情况下发生。我实际上希望我只能通过配置以某种方式做到这一点。在过去的 2 到 3 天里,我一直在阅读我能找到的关于这个问题的所有内容。我了解
我有一个非常简单的带有maven的ejb 3.0模块,它只有两个 session bean,一个是无状态的,另一个是单例的...当我尝试在Glassfish 3.0服务器上部署该项目时,我得到了这个异
我们在微服务中看到的是一个孤立的组件,通过协议(protocol)通过网络与该组件的父消费者进行通信。 我们在 EJB 1.0 中看到了非常相似的模式。 我的问题是:微服务架构模式是否类似于 EJB
我在 Java EE6 Singleton Session Bean 中有一个方法,它每 30 秒由 @Schedule(...) 计时器调用。这按预期工作,直到在方法中抛出并捕获异常(异常在 try
我正在 JDeveloper 11.1.1.4 中开发一个 JAX-WS WebService,它应该使用之前部署到 WebLogic 服务器的 JAR 中的 EJB。 WebService项目和EJ
我正在尝试使用 JAX-RS 注释将一些 EJB 公开为 REST Web 服务。当我部署 war WEB-INF/lib 中包含 EJB Jar 的文件到 Wildfly 8,我可以在 Web 管理
我是 EJB 方面的新手,但我已经获得了 EJB 级别的提升。 该层由一个 EJB 组成,它公开可用的操作: @Stateless(name = "myejb") public class Facad
假设我想创建一个我将在未来项目中使用的库,但我还想在该库中包含引用其他 EJB 等的 EJB。该库还将包含简单的 Java 类。最好的方法是什么?在这种情况下如何定义依赖关系?我想我会用注释来定义它们
我想知道是否可以按照这些思路做一些事情: 1)服务器端(EJB类) @Statefull public class SomeEJB implements SomeEJBRemote { @Resour
我是一名优秀的程序员,十分优秀!