PetShop4.0 基于.net3.5构建,整个解决方案由23个工程组成,各工程之间的关系如下:
图中红色虚线表示层间分隔,PetShop4.0中大量使用了F/I/C模式(工厂/接口/实现),第3层中的IDAL,IMessaging,IProfileDAL(包括第2层中的ICacheDependency)是F/I/C中的接口,Model中包含值对象的定义(仅包含属性和构造函数)。
第2层中的ICacheDependency,TableCacheDependency,CacheDependency,Membership,
SyndicationFeeds,Profile(粉红色标识)属于技术支持类工程,BLL和IBLLStrategy是业务实现类工程,其中BLL和IBLLStrategy采用了一个策略模式(GOF,Strategy)进行耦合。
第1层中的Web(网站)和OrderProcessor(后台服务),可以理解为表示层和业务驱动层。
引出的第一个问题是,MSMQ(微软消息队列)在系统中的用途,为阐释这个问题,请看下图:
图中对BLL工程中的Order对象进行了一个简单的静态建模,在Order对象的Insert方法中采用了策略模式(GOF,Strategy),其中,同步存储策略(OrderSynchronous)存储到数据库,异步存储策略(OrderAsynchronous)插入消息到消息队列,第1层中的OrderProcessor工程最主要任务就是从消息队列中取出Order对象,进行处理(存储)。
从架构师的角度来看,仅从工程命名就能够明白系统中各组件的耦合模式,不失为一条值得学习的原则。
今天就先写到这里。