目标:
通过本文,学习如何采用Core J2EE Patterns架构具有高度扩展性多层的J2EE应用。
作者:
Deepak Alur
- Senior Software Architect, SunPS program
- Co-author of Core J2EE Patterns
- Sun-eBay V3 Architecture—Team leader
Arnold Goldberg
- Lead Architect—eBay.com Platform
- Led V3 architecture, design and implementation
Raj Krishnamurthy
- Software Architect, SunPS program
- Sun-eBay V3 Architecture team—Key member
议程:
入门和Core J2EE Patterns
eBay.com三层架构的目标
关键架构和技术决策
eBay.com如何应用Core J2EE Patterns
结论
一、入门和Core J2EE Patterns
1、目标:
- eBay.com网站的架构
- 架构中模式的地位
- 使用 Core J2EE Patterns的好处
2、eBay介绍
(1)使命
1、全球交易平台
2、拍卖、定价、B2C、B2B
(2)统计数据
- 6900万注册会员
- 28000个分类,1600万商品
- 2002年营业额:148亿7千万美元
-全球社区
-每天十亿次访问量
- 1200多个URL
3、eBay旧的二层架构及其存在的问题
(1)ebay旧的二层架构
-集成在一起的两层架构(架构中各组件之间的耦合度高)
- 330万行C++ ISAPI DLL
-面向功能的设计
- Not for systemic qualities
(2)二层架构存在的问题
-阻碍商业创新(可扩展性不够)
-随着访问量增大,系统线性扩展性面临着挑战(无法通过仅仅增加硬件投入,扩充系统的支撑量)
-高额的维护成本
-不便于“重构”(代码很难通过重构来改善)
- Architects in constant Fire-Fighting Mode
4、2000年底开始三层架构改造
系统向分层、松散耦合、模块化、基于标准的架构过渡
5、ebay架构的改造是基于下面这本书介绍的模式core J2EE Pattern 最佳实践和设计策略第二版,sun官方网站也提供core J2EE Pattern,见 http://java.sun.com/blueprints/corej2eepatterns/Patterns/
该书介绍了21 种J2EE设计模式,我们可以把他们归类到三层中。
(1)、表示层的设计模式:
- Intercepting Filter (X)
- Front Controller (X)
- Application Controller (X)
- Context Object (X)
- View Helper
- Composite View
- Service To Worker (X)
- Dispatcher View
带(X)表示这些设计模式在eBay.com的架构中采用了。
(2)、商业逻辑层的设计模式:
- Business Delegate
- Service Locator (X)
- Session Facade
- Application Service (X)
- Business Object (X)
- Composite Entity
- Transfer Object (X)
- Transfer Object Assembler (X)
- Value List Handler (X)
带(X)表示这些设计模式在eBay.com的架构中采用了。
3、集成层(也称为数据访问层) 设计模式:
- Data Access Object (X)
- Service Activator
- Domain Store (X)
- Web Service Broker (X)
带(X)表示这些设计模式在eBay.com的架构中采用了。
二、ebay三层架构的目标
1、目标
高可用性、高可靠性、可线性扩展,建立实现系统的无缝增长。
高开发效率,支持新功能的快速交付。
可适应未来的架构,应变将来商业的更新需求。
ebay的系统可用性2002年已到了99.92%.(令人叹服),每季度网站新增十五个重大功能,
每个星期将近3万行代码在修改,3个星期内可以提供一个国际化版本。
2、为了可适应未来的架构,ebay采用了下面的做法
采用J2EE模式
Only adopt Technology when required
Create new Technology as needed
大量的性能测试
大量的容量计划
大量关键点的调优
Highly redundant operational infrastructure and the technology to leverage it
3、为了实现可线性扩展,ebay采用了下面的做法:
(1) 合理地使用server state
(2) No server affinity
(3) Functional server pools。
(4) Horizontal and vertical database partitioning。
ebay架构采用了服务器分块化的概念,每台服务器上的应用与它的use case有关,即server pool中的一部分服务器专门用于登陆,一部分服务器专门用于显示商品信息。毕竟不同use case访问数据库的方式不同,比如“显示商品信息”use case只是只读操作。而且由于是只读操作,数据库的压力会比较低,我可以只采用几台服务器来承担这部分操作,而更多的服务器用于读写操作多的use case,这样合理地使用服务器资源。由于不同的应用放在不同的服务器上,这里就涉及到用户状态的复制问题。这就是第一条ebay要求合理地使用server state的原因,就我所知,ebay的用户状态只有很少保存在session中,ebay把用户的状态放到了数据库和cookie中。
4、为了使得数据访问可线性扩展
(1) 建模我们的数据访问层
(2) 支持Support well-defined data access patterns
Relationships and traversals
本地cache和全局cache
(3) 定制的O-R mapping—域存储模式
(4) Code generation of persistent objects
(5) 支持lazy loading
(6) 支持fetch sets (shallow/deep fetches)
(7) 支持retrieval and submit (Read/Write sets)
5、为了使数据存储可线性扩展,eBay采用了下列做法
(1)商业逻辑层的事务控制
只采用Bean管理的事务
Judicious use of XA
数据库的自动提交
(2)基于内容的路由
运行期间采用 O-R Mapping ,找到正确的数据源
支持数据库的水平线性扩展
Failover hosts can be defined
(3)数据源管理
动态的
Overt and heuristic control of availability
如果数据库宕机,应用可以为其他请求服务。
6、应变未来采用的技术
(1)消息系统
子系统之间、数据库之间松散耦合
J2EE的Message Driven Beans
(2)SOAP
对于外部开发者和合作伙伴,通过可用的工具和最佳实践来平衡我们的平台
采用SOAP 来标准化不同eBay应用之间进程内部的通信
采用SOAP满足我们的QoS需求
四、将J2EE的设计模式应用到eBay中
介绍了三个Use cases例子,“查看账号”,“查看商品”,“eBayAPI”,介绍了这三个use case 如何采用J2EE的设计模式实现其设计。
分享到:
相关推荐
《SUN - Core J2EE patterns》一书深入探讨了Java 2 Platform, Enterprise Edition (J2EE)架构中的设计模式与最佳实践,为开发者提供了一套系统化的解决方案,旨在帮助他们在复杂的企业级应用开发中避免常见的陷阱和...
《J2EE核心模式(Core J2EE Patterns)》是一本深度探讨J2EE平台设计模式的权威著作,由SUN公司的资深工程师倾力撰写。这本书是Java企业级开发者的必备参考书籍,它揭示了在复杂的企业级应用开发中,如何有效地利用...
《Core J2EE Patterns》是Java企业级应用开发的经典之作,它详细介绍了在J2EE平台上构建可扩展、高效、可维护的系统所使用的最佳实践和设计模式。这本书的第二版源码对于深入理解J2EE开发中的核心概念和技术具有极高...
- **Data Access Object Pattern**: 此模式定义了一组访问数据库的方法,将数据访问逻辑从应用程序主体中分离出来,提高了代码的可维护性和可测试性。 - **Business Delegate Pattern**: 通过引入一个中间层来处理...
J2EE因遵循“一次编写,到处运行”的原则,具有较好的跨平台性,但实际部署时,往往需要选择特定的J2EE应用服务器,如WebLogic、JBoss或GlassFish,这可能影响到移植性。 .NET Framework主要针对Windows平台,虽然...
中文版压缩成2卷,这是第一卷。 本书讲解使用J2EE核心技术实现企业应用过程中的模式、最佳实践、设计策略以及经过验证的解决方案,涵盖了JSP、servlet、EJB、JMS等技术,其中J2EE模式目录包括21个模式以及大量策略...
《核心的J2EE设计模式》是一本专为Java企业级开发者编写的经典著作,它深入探讨了在J2EE平台上构建可扩展、高效且可维护的系统所使用的最佳实践和设计模式。这本书的第二版进一步更新了内容,以适应不断演进的Java...
Core J2EE Patterns
标题《Core J2EE Patterns Best Practices And Design Strategies》和描述部分介绍了软件设计模式的重要性,将设计模式比喻为一个组织的“部落记忆”的有形体现。设计模式是解决常见问题的通用解决方案,它源自之前...
prentice hall - core j2ee patterns - best practices and design strategies, second edition.part1
### J2EE电子商务系统开发从入门到精通:基于Struts和Hibernate技术实现 #### J2EE概论 - **双层架构与多层架构的区别**: - 双层架构通常指的是客户端/服务器(Client/Server, C/S)架构,这种架构下的应用程序在...
- **J2EE**通常采用Java作为主要开发语言,具有丰富的开源库和社区支持。J2EE强调模块化和标准化,使得开发人员能够更容易地构建大型企业级应用。 - **.NET**支持多种语言,包括C#、VB.NET等。.NET平台提供了丰富的...
《J2EE Core Design Patterns》是一本专注于Java企业级应用开发中的核心设计模式的重要书籍。设计模式是软件工程中经过实践验证的、解决特定问题的模板,尤其在复杂如J2EE(Java 2 Platform, Enterprise Edition)...
### 利用MyEclipse构建Struts+Hibernate+Spring的J2EE系统经典例子 #### 系统背景与概述 本案例旨在通过一个简单的用户注册系统来演示如何使用MyEclipse集成开发环境(IDE)搭建基于Struts、Hibernate以及Spring...
prentice hall - core j2ee patterns - best practices and design strategies, second edition.part2
prentice hall - core j2ee patterns - best practices and design strategies, second edition.part3
《Core J2EE Patterns 2nd Edition》是Java企业级应用开发的重要参考资料,它全面而深入地探讨了在J2EE平台上构建可扩展、高效且易于维护的应用程序所采用的设计模式。这本书的第二版更新了早期版本的内容,以适应...
《Core J2EE Patterns(Second Edition)》是Java企业级应用开发的重要参考资料,它深入探讨了J2EE(Java 2 Platform, Enterprise Edition)平台上的设计模式和最佳实践。这本书的.chm格式意味着它是一个微软的帮助...
- **Singleton**:确保一个类只有一个实例,并提供一个全局访问点。 - **Decorator**:动态地给一个对象添加新的职责。 此外,书中还提供了大量的策略和技巧,如重构策略,以帮助读者优化现有的系统结构。 #### 五...