petshop4.0项目概述与架构分析
来源:互联网 发布:传智python就业班 编辑:程序博客网 时间:2024/05/16 02:36
1.项目概述与架构分析
微软刚推出了基于ASP.NET 2.0下的Pet Shop 4, 该版本有了一个全新的用户界面。是研究ASP.NET 2.0的好范例啊,大家都知道,一直以来,在.NET和Java之间争论不休,到底使用哪个平台开发的企业级应用性能最好、结构最优、生产力最高。为了用事实说话,通过对项目各方面的性能评估进而在比较.NET和Java的高下。用户做比较的这个项目就是Petshop。正因为Petshop肩负着上面所说的重任,各方面必须是最优的,架构设计应该是经过慎重考虑的。所以其一经推出,便成为了开发者、架构师等人学习、研究的典范。
日前微软推出了基于.NET Framework 2.0开发的Petshop 4。新的Petshop4实现了与Petshop 3相同甚至更多的特性,由于采用了Master Pages,Membership,以及Profile,SqlCacheDependency,但是代码量却减少了四分之一。同时,在事务、数据缓存、安全方面使用了.NET 2.0附带的特性,构建了一个灵活的最佳实践的应用程序。
他们利用了Project Conversion Wizard把项目从ASP.NET 1.1移植到了ASP.NET 2.0,然后做了以下改动:
1.用System.Transactions代替了原来的Serviced Components提供的事务功能
代码实现:PetShop.BLL.OrderSynchronous 的 public void Insert(PetShop.Model.OrderInfo order)。
2.用强类型的范型集合代替了原来的弱类型集合
3.采用ASP.NET 2.0 Membership来做认证和授权
4.创建了针对Oracle 10g的Custom ASP.NET 2.0 Membership Provider
5.利用ASP.NET 2.0的Custom Oracle 和 SQL Server Profile Providers 做用户状态管理,包括购物车等
6.采用了Master Pages,取代了原来的用户控件,来实现统一的界面效果
7.使用了ASP.NET 2.0 Wizard控件实现check-out
8.使用了SqlCacheDependency来实现数据库层次的缓存更新(cache invalidation)功能
9.使用了消息队列来实现异时订单处理。
2.整体架构:
数据库:(暂略)
项目列表:从整体可以看出,Pet Shop 4的项目体系已经很庞大,考虑的方面也较3.0更全面复杂。
业务逻辑层
缓存依赖类的工厂类
表示层
数据层的抽象工厂
数据访问类组件
同步/异步策略接口
缓存依赖类接口
数据访问层接口定义
异时处理消息队列接口定义
Profile的数据访问层接口定义
Membership认证和授权管理
异时处理消息队列的抽象工厂
业务实体
异时处理消息队列的实现
Oracle数据访问层
Oracle的Profile Providers
做用户状态管理,包括购物车等
后台处理进程,处理订单队列
Profile的数据访问层
ProfileDAL的工厂类(反射创建ProfileDAL)
SQL Server 的Profile Providers
做用户状态管理,包括购物车等
SQLServer数据访问层
缓存依赖实现类
项目分解:
由于整体已经有22个项目,所以,对于初学者一看就晕了,所以,我做了分解,可以大体上分几块去理解。
表示层
业务实体
业务逻辑层
数据层的抽象工厂
数据访问层接口定义
SQLServer数据访问层
Oracle数据访问层
数据库访问组件基础类
缓存依赖类的工厂类
缓存依赖类接口
缓存依赖实现类
同步/异步处理策略接口(实现在bll根据配置反射选择)
异时处理消息队列的抽象工厂
异时处理消息队列接口定义
异时处理消息队列的实现
Profile的数据访问层
ProfileDAL的工厂类(反射创建ProfileDAL)
Profile的数据访问层接口定义
Oracle的Profile Providers
做用户状态管理
SQL Server 的Profile Providers
做用户状态管理
Membership认证和授权管理
后台处理进程,处理订单队列
3.Petshop 4中的设计模式:
工厂模式:
首当其冲的就是工厂模式,很容易就可以看出来,也是应用最多的。
DALFactory:数据访问层的抽象工厂(决定创建哪种数据库类型的数据访问层。可以选择:SQLServer,Oracle)
CacheDependencyFactory:缓存依赖类的工厂类。(创建具体表的缓存依赖)
MessagingFactory :异时处理消息队列的抽象工厂(反射创建具体的异时处理类)
ProfileDALFactory:ProfileDAL的工厂类(反射选择创建Oracle 和SQL Server的 ProfileDAL)
策略模式: IorderStrategy
中介模式
CategoryDataProxy ItemDataProxy ProductDataProxy
暂时只看了这么多,以后有时间继续分解,如果你有不同的见解或经验,也请写下来,好让大家来共同学习,共同探讨,共同进步。
1.项目概述与架构分析
微软刚推出了基于ASP.NET 2.0下的Pet Shop 4, 该版本有了一个全新的用户界面。是研究ASP.NET 2.0的好范例啊,大家都知道,一直以来,在.NET和Java之间争论不休,到底使用哪个平台开发的企业级应用性能最好、结构最优、生产力最高。为了用事实说话,通过对项目各方面的性能评估进而在比较.NET和Java的高下。用户做比较的这个项目就是Petshop。正因为Petshop肩负着上面所说的重任,各方面必须是最优的,架构设计应该是经过慎重考虑的。所以其一经推出,便成为了开发者、架构师等人学习、研究的典范。
日前微软推出了基于.NET Framework 2.0开发的Petshop 4。新的Petshop4实现了与Petshop 3相同甚至更多的特性,由于采用了Master Pages,Membership,以及Profile,SqlCacheDependency,但是代码量却减少了四分之一。同时,在事务、数据缓存、安全方面使用了.NET 2.0附带的特性,构建了一个灵活的最佳实践的应用程序。
他们利用了Project Conversion Wizard把项目从ASP.NET 1.1移植到了ASP.NET 2.0,然后做了以下改动:
1.用System.Transactions代替了原来的Serviced Components提供的事务功能
代码实现:PetShop.BLL.OrderSynchronous 的 public void Insert(PetShop.Model.OrderInfo order)。
2.用强类型的范型集合代替了原来的弱类型集合
3.采用ASP.NET 2.0 Membership来做认证和授权
4.创建了针对Oracle 10g的Custom ASP.NET 2.0 Membership Provider
5.利用ASP.NET 2.0的Custom Oracle 和 SQL Server Profile Providers 做用户状态管理,包括购物车等
6.采用了Master Pages,取代了原来的用户控件,来实现统一的界面效果
7.使用了ASP.NET 2.0 Wizard控件实现check-out
8.使用了SqlCacheDependency来实现数据库层次的缓存更新(cache invalidation)功能
9.使用了消息队列来实现异时订单处理。
2.整体架构:
数据库:(暂略)
项目列表:从整体可以看出,Pet Shop 4的项目体系已经很庞大,考虑的方面也较3.0更全面复杂。
业务逻辑层
缓存依赖类的工厂类
表示层
数据层的抽象工厂
数据访问类组件
同步/异步策略接口
缓存依赖类接口
数据访问层接口定义
异时处理消息队列接口定义
Profile的数据访问层接口定义
Membership认证和授权管理
异时处理消息队列的抽象工厂
业务实体
异时处理消息队列的实现
Oracle数据访问层
Oracle的Profile Providers
做用户状态管理,包括购物车等
后台处理进程,处理订单队列
Profile的数据访问层
ProfileDAL的工厂类(反射创建ProfileDAL)
SQL Server 的Profile Providers
做用户状态管理,包括购物车等
SQLServer数据访问层
缓存依赖实现类
项目分解:
由于整体已经有22个项目,所以,对于初学者一看就晕了,所以,我做了分解,可以大体上分几块去理解。
表示层
业务实体
业务逻辑层
数据层的抽象工厂
数据访问层接口定义
SQLServer数据访问层
Oracle数据访问层
数据库访问组件基础类
缓存依赖类的工厂类
缓存依赖类接口
缓存依赖实现类
同步/异步处理策略接口(实现在bll根据配置反射选择)
异时处理消息队列的抽象工厂
异时处理消息队列接口定义
异时处理消息队列的实现
Profile的数据访问层
ProfileDAL的工厂类(反射创建ProfileDAL)
Profile的数据访问层接口定义
Oracle的Profile Providers
做用户状态管理
SQL Server 的Profile Providers
做用户状态管理
Membership认证和授权管理
后台处理进程,处理订单队列
3.Petshop 4中的设计模式:
工厂模式:
首当其冲的就是工厂模式,很容易就可以看出来,也是应用最多的。
DALFactory:数据访问层的抽象工厂(决定创建哪种数据库类型的数据访问层。可以选择:SQLServer,Oracle)
CacheDependencyFactory:缓存依赖类的工厂类。(创建具体表的缓存依赖)
MessagingFactory :异时处理消息队列的抽象工厂(反射创建具体的异时处理类)
ProfileDALFactory:ProfileDAL的工厂类(反射选择创建Oracle 和SQL Server的 ProfileDAL)
策略模式: IorderStrategy
中介模式
CategoryDataProxy ItemDataProxy ProductDataProxy
暂时只看了这么多,以后有时间继续分解,如果你有不同的见解或经验,也请写下来,好让大家来共同学习,共同探讨,共同进步。
- petshop4.0项目概述与架构分析
- PetShop4.0架构分析
- PetShop4.0架构分析
- PetShop4.0架构分析
- PetShop4.0架构分析
- PetShop4.0架构分析
- PetShop4.0架构分析
- PetShop4.0架构分析 (转载)
- petshop4.0 petshop经典架构分析
- PetShop4架构设计分析(二)
- PetShop4架构设计分析(一)
- PetShop4架构设计分析(二)
- PetShop4架构设计分析(三)
- PetShop4架构设计分析(四)
- PetShop4架构设计分析(五)
- PetShop4架构设计分析(六)
- PetShop4架构设计分析(七)
- PetShop4.0架构分析及工厂模式的使用
- 【新手学习】Excel操作指南 之一
- apache服务器配置全攻略
- 踏入C++中的雷区——C++内存管理详解
- 从内核模式启动进程
- WEBSITE
- petshop4.0项目概述与架构分析
- CMM介绍一
- 一张浓缩大学生活的顶级报(转载)
- 杀毒引擎外一篇--讨论杀软卡机的原理
- 还原完整备份的语法如下:
- web 性能测试小结
- 跟踪Native API函数调用
- CMM介绍二
- 超强的毅力+坚定的信念=疯子