- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
one-on-one J2EE Development without EJB
一. Why J2EE without EJB?
1.1 Spring对比EJB的优点
a.新技术的出现 AOP/IOC/Dynamic Proxy
b.Test(TDD)(以为有EJB容器)
c.OO 耦合 复杂 效率(分布,多客户端)
d.分布,远程 (少) ,且RMI可用Webservice的替换
1.2 几个问题:
Hibernate ---Entity Bean
Why singleton cannot in EJB?
由于Ejb的单线程编程,一个EJB实例在同一个时间只能服务一个线程。
Ioc---JNDI
Ioc应该从Delegate演变过来的
Web容器提供了线程池, EJB容器也提供了,为啥?(RMI提供远程服务时,需要EJB提供的线程池)
JTA/jdbc 事务区别?
i. 本地事务:完全依赖于db,jms本身。如jdbc的conn.Commit();
ii. 分布式事务:在JavaEE世界的事务在JTA、JTS规范和XA Sources之上实现。
OO原则:针对接口编程,而非针对类编程是原则----DIP?
Message 与Apache commons Messenger 有关系吗? 如果不是,是什么?
无状态:表示你任何一次调用(或执行)都是一样的。
设计: 以业务和OO为驱动,降低复杂度
二. Gols
2.1 反OO :
1. 没有行为的对象(DTO, Entity Bean)
2. Session Fa?ade模式等
一定要在项目初期就开发一个垂直切片来验证应用的架构
三. Architecture
三层模型
Web层:应该很薄,应该搭建在服务层上面,其代码只是用来解释用户的操作和显示响应的结果。
业务层:1、业务层的一个主要动机就是要在多个客户端之间共享资源。
2、提供一个逻辑层,提供便于测试和事务管理。
Q1. 为什么说无状态服务层是违背面向对象的一种妥协?
因为无状态对象不能把状态提供给调用者,但是他们有内部状态,也完全具有继承关系
数据访问层:
Q1. 从持久化存储断开是一个常见而重要的问题?离线访问?
比如Hibernate中,POJO从持久对象变成托管对象。
Q2。如何访问遗留系统
JCA(Java Connection Architecture:Java连接架构),用来为后端系统(特别是非关系型的数据存储)提供一种共通的访问机制。包括资源管理和事务管理。
任何EIS只要通过JCA适配器,就可以插入如何兼容于JCA的j2ee容器。JCA也应该由应用服务器提供实现。
从总体来说,j2ee容器向JCA连接器提供的服务与JDBC连接基本类似。
容器会把连接放到缓存池
如果连接器兼容于XA规范,那么就可以参与JTA事务。
在启动时,容器会把连接工厂绑定到一个JNDI location.
采用了JCA,就可以使ERP系统和其他后端系统集成起来(这也是该规范的初衷)。
ERP厂商(比如SAP)负责提供JCA连接器,这样用户就能以标准的、支持事务的方式访问他们的系统。
对象
业务对象(BO):
领域对象:(DO)
传输对象(DTO):
值对象(VO):
POJO
并置:在同一台主机,同一个虚拟机中
应该并置业务对象和web容器,这是最简单,最高效,最符合面向对象原则的一种方案。
在web服务器和J2EE web容器之间,可能会有一种分布式的边界。比如说,可能用Apache作为Http服务器,然后通过一个代理连接器,把请求送给后台的J2ee web容器,这种只对性能有所影响,有时有安全方面的理由:这样做之后,J2EE服务器的所有部分就都可以放在一个防火墙后面。
清晰的业务层的重要性?
a。简单,便于扩展和移植
b。便于测试
c。提供企业级管理(比如事务,缓冲池)
I 远程EJB
强项:
提供一个共享的中间层,就能够支持各种类型的j2ee客户端。
II 本地EJB
III 特制J2EE架构
IV “轻量级容器“架构
轻量级容器并没有和J2ee绑定,所以他既可以运行在web容器中,也可以在标准应用程序中运行。如果必要,甚至EJB容器中运行。
这个容器也没有和Servlet API绑定,区别于MVC框架
四.The Simplicity Dividend
4.1 分布式存在的问题
性能:
告别OO:欢迎TO。专门采用一个传输对象层,就会阻碍调用者和被调用者高效地共享一个完整的领域模型,因此也很快就会导致代码膨胀。
部署问题:我们需要在不同节点之间保持代码同步,因此,在一个集群上部署新的二进制程序时非常复杂的工作。
异常处理问题:所有的远程调用都要面临网络故障问题,而要想具备从这种故
您可能关注的文档
最近下载
- 钢结构加工制作方案 (2).doc VIP
- 检验科病例讨论PPT课件.pptx VIP
- SIMATIC WINCC V7.5使用C脚本通过画面结合结构变量实现多个电机的控制功能.docx VIP
- PS液压盘式刹车零件图册.pdf VIP
- bim实施管理标准(深圳).pdf VIP
- (高清版)DB41∕T 1993-2020 山水林田湖草生态保护修复工程监理规范.pdf VIP
- 中国当代文学完整课件.ppt VIP
- 眼睑痉挛残疾指数、Jankovic、西多伦多痉挛性斜颈评分量表、颅颈肌张力障碍问卷、嗓音障碍指数.docx VIP
- 经史子集国学文库:史部·地理·长乐六里志.pdf
- 淮南市社区工作者招聘笔试真题2024.docx VIP
文档评论(0)