Microsoft .NET Pet Shop 4 架构与技术分析

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介:

1.项目概述与架构分析

微软刚推出了基于ASP.NET 2.0下的Pet Shop 4, 该版本有了一个全新的用户界面。是研究ASP.NET 2.0的好范例啊,大家都知道,一直以来,在.NETJava之间争论不休,到底使用哪个平台开发的企业级应用性能最好、结构最优、生产力最高。为了用事实说话,通过对项目各方面的性能评估进而在比较.NETJava的高下。用户做比较的这个项目就是Petshop。正因为Petshop肩负着上面所说的重任,各方面必须是最优的,架构设计应该是经过慎重考虑的。所以其一经推出,便成为了开发者、架构师等人学习、研究的典范。
日前微软推出了基于.NET Framework 2.0开发的Petshop 4。新的Petshop4实现了与Petshop 3相同甚至更多的特性,由于采用了Master PagesMembership,以及ProfileSqlCacheDependency,但是代码量却减少了四分之一。同时,在事务、数据缓存、安全方面使用了.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 .用强类型的范型集合代替了原来的弱类型集合
        public IList<ProductInfo> GetProductsByCategory(string category)
        {
            // Return new if the string is empty
            if (string.IsNullOrEmpty(category))
                return new List<ProductInfo>();
 
            // Run a search against the data store
            return dal.GetProductsByCategory(category);
        }
3 .采用ASP.NET 2.0 Membership来做认证和授权
4 .创建了针对Oracle  10g Custom  ASP.NET 2.0 Membership Provider
5 .利用ASP.NET 2.0Custom 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更全面复杂。
 
序号
项目名称
描述
1
BLL
业务逻辑层
2
CacheDependencyFactory
缓存依赖类的 工厂类
3
WEB
表示层
4
DALFactory
数据层的抽象工厂
5
DBUtility
数据访问类组件
6
IBLLStrategy
同步/异步策略接口
7
ICacheDependency
缓存依赖类 接口
8
IDAL
数据访问层接口定义
9
IMessaging
异时处理消息队列接口定义
10
IProfileDAL
Profile 的数据访问层接口定义
11
Membership
Membership 认证和授权管理
12
MessagingFactory
异时处理消息队列的 抽象工厂
13
Model
业务实体
14
MSMQMessaging
异时处理消息队列的实现
15
OracleDAL
Oracle 数据访问层
16
OracleProfileDAL
Oracle Profile Providers
做用户状态管理,包括购物车等
17
OrderProcessor
后台处理进程,处理订单队列
18
Profile
Profile 的数据访问层
19
ProfileDALFactory
ProfileDAL 的工厂类(反射创建ProfileDAL)
20
SQLProfileDAL
SQL Server  Profile Providers
做用户状态管理,包括购物车等
21
SQLServerDAL
SQLServer 数据访问层
22
TableCacheDependency
缓存依赖实现类
 
项目分解
由于整体已经有22个项目,所以,对于初学者一看就晕了,所以,我做了分解,可以大体上分几块去理解。
序号
项目名称
描述
1
WEB
表示层
2
Model
业务实体
3
BLL
业务逻辑层
4
DALFactory
数据层的抽象工厂
5
IDAL
数据访问层接口定义
6
SQLServerDAL
SQLServer 数据访问层
7
OracleDAL
Oracle 数据访问层
8
DBUtility
数据库访问组件基础类
9
CacheDependencyFactory
缓存依赖类的 工厂类
10
ICacheDependency
缓存依赖类 接口
11
TableCacheDependency
缓存依赖实现类
12
IBLLStrategy
同步/异步处理策略接口(实现在bll根据配置反射选择)
13
MessagingFactory
异时处理消息队列的 抽象工厂
14
IMessaging
异时处理消息队列接口定义
15
MSMQMessaging
异时处理消息队列的实现
16
Profile
Profile 的数据访问层
17
ProfileDALFactory
ProfileDAL 的工厂类(反射创建ProfileDAL)
18
IProfileDAL
Profile 的数据访问层接口定义
19
OracleProfileDAL
Oracle Profile Providers
做用户状态管理
20
SQLProfileDAL
SQL Server  Profile Providers
做用户状态管理
21
Membership
Membership 认证和授权管理
22
OrderProcessor
后台处理进程,处理订单队列
 
 
 
3 Petshop 4中的设计模式
工厂模式 :
首当其冲的就是工厂模式,很容易就可以看出来,也是应用最多的。
DALFactory :数据访问层的抽象工厂(决定创建哪种数据库类型的数据访问层。可以选择:SQLServerOracle
CacheDependencyFactory 缓存依赖类的 工厂类。(创建具体表的缓存依赖)
MessagingFactory  异时处理消息队列的 抽象工厂(反射创建具体的 异时处理类
ProfileDALFactory ProfileDAL 的工厂类(反射 选择 创建Oracle SQL Server的 ProfileDAL)
 
策略模式 IorderStrategy
 
 
 
中介模式
CategoryDataProxy ItemDataProxy  ProductDataProxy
 
 
 
暂时只看了这么多,以后有时间继续分解,如果你有不同的见解或经验,也请写下来,好让大家来共同学习,共同探讨,共同进步。
 
(作者:李天平    转载请注明)
 
具体介绍可以参看MSDN
.NET Pet Shop 4: Migrating an ASP.NET 1.1 Application to 2.0




本文转自 litp 51CTO博客,原文链接:http://blog.51cto.com/litianping/123836,如需转载请自行联系原作者
 
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
1月前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
26天前
|
监控 安全 API
使用PaliGemma2构建多模态目标检测系统:从架构设计到性能优化的技术实践指南
本文详细介绍了PaliGemma2模型的微调流程及其在目标检测任务中的应用。PaliGemma2通过整合SigLIP-So400m视觉编码器与Gemma 2系列语言模型,实现了多模态数据的高效处理。文章涵盖了开发环境构建、数据集预处理、模型初始化与配置、数据加载系统实现、模型微调、推理与评估系统以及性能分析与优化策略等内容。特别强调了计算资源优化、训练过程监控和自动化优化流程的重要性,为机器学习工程师和研究人员提供了系统化的技术方案。
146 77
使用PaliGemma2构建多模态目标检测系统:从架构设计到性能优化的技术实践指南
|
15天前
|
机器学习/深度学习 存储 人工智能
基于AI的实时监控系统:技术架构与挑战分析
AI视频监控系统利用计算机视觉和深度学习技术,实现实时分析与智能识别,显著提升高风险场所如监狱的安全性。系统架构包括数据采集、预处理、行为分析、实时决策及数据存储层,涵盖高分辨率视频传输、图像增强、目标检测、异常行为识别等关键技术。面对算法优化、实时性和系统集成等挑战,通过数据增强、边缘计算和模块化设计等方法解决。未来,AI技术的进步将进一步提高监控系统的智能化水平和应对复杂安全挑战的能力。
|
1月前
|
运维 Cloud Native 持续交付
云原生技术深度探索:重塑现代IT架构的无形之力####
本文深入剖析了云原生技术的核心概念、关键技术组件及其对现代IT架构变革的深远影响。通过实例解析,揭示云原生如何促进企业实现敏捷开发、弹性伸缩与成本优化,为数字化转型提供强有力的技术支撑。不同于传统综述,本摘要直接聚焦于云原生技术的价值本质,旨在为读者构建一个宏观且具体的技术蓝图。 ####
|
2月前
|
Cloud Native 持续交付 云计算
云原生技术在现代IT架构中的转型力量####
本文深入剖析了云原生技术的精髓,探讨其在现代IT架构转型中的关键作用与实践路径。通过具体案例分析,展示了云原生如何赋能企业实现更高效的资源利用、更快的迭代速度以及更强的系统稳定性,为读者提供了一套可借鉴的实施框架与策略。 ####
28 0
|
2月前
|
运维 Kubernetes Docker
深入理解容器化技术及其在微服务架构中的应用
深入理解容器化技术及其在微服务架构中的应用
68 1
|
2月前
|
监控 Java 微服务
从零构建微服务架构:一次深度技术探索之旅####
本文作为一篇深度技术分享,引领读者踏上自底向上搭建微服务架构的征途,旨在通过实战经验剖析,揭示微服务转型背后的技术挑战与解决方案。不同于常规摘要仅概述内容,本文摘要将直接以故事化手法,简述作者从单体应用困境出发,逐步迈向微服务化的心路历程,涵盖关键决策点、技术选型考量及实践收获,激发读者对微服务架构设计与实现的浓厚兴趣。 ####
|
2月前
|
Cloud Native 持续交付 云计算
深入理解云原生技术及其在现代IT架构中的应用
在数字化浪潮的推动下,云原生技术已成为企业转型的关键。本文将通过浅显易懂的语言和生动的比喻,带领读者探索云原生的核心概念、优势以及如何在企业中实现云原生架构。我们将一起揭开云原生的神秘面纱,了解它如何助力企业快速适应市场变化,提升业务的灵活性和创新能力。
|
2月前
|
敏捷开发 缓存 中间件
.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素
本文深入探讨了.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素,并通过企业级应用和Web应用开发的实践案例,展示了如何在实际项目中应用这些模式,旨在为开发者提供有益的参考和指导。
43 3
|
2月前
|
Cloud Native 云计算 Docker
云原生技术的崛起:从容器化到微服务架构
云原生技术的崛起:从容器化到微服务架构