各频道分别位于不同的Web Project(具有独立的二级域名),并将所有的业务逻辑以及数据访问功用封装成Class Library,所有频道共用这个Class Library。 主体架构 
   各频道分别位于不同的Web  Project(具有独立的二级域名),并将所有的业务逻辑以及数据访问功用封装成Class Library,所有频道共用这个Class Library。  下面详细引见实现方法。  假设网站有三个频道,旧事、论坛以及博客,对应的二级域名为"news"、"forum"、"blog"。除此之外,还需求另外定义两个域名,分别用于网站首页以及用户注册、登陆功用(基于Passport机制,本文后面将作详细引见),对应域名为"homepage"、"passport"。  1.配置各频道URL  a.配置hosts文件  用文本编辑器打开hosts文件(位于c:\windows或winnt\system32\drivers\etc\),该文件中存放初始的域名解析信息。当我们在浏览器中请求某个URL时,系统首先在hosts文件中查找相应域名,如果找到则跳转至指定IP,如果没找到,则进一步提交DNS进行域名解析。  配置很简单,格式形如"[IP][空格][域名]",每条数据对应一行。下面为配置内容:  192.168.1.2 www.mysite.com  192.168.1.2 passport.mysite.com  192.168.1.3 news.mysite.com  192.168.1.5 forum.mysite.com  192.168.1.9 blog.mysite.com  你可能曾经留意到了,各频道对应于不同的IP,这正是该架构的开发灵活性所在。各频道(Web Project)可以创建于不同的开发者电脑。通过将配置内容同步到各台电脑,可以方便的在各频道间进行页面浏览,就像这些频道位于你本人的电脑一样!采用这种方式可以极大降低开发耦合性,每个频道都是一个独立的模块,一个频道中的Bug不会影响到另一个频道。  b.配置Web.Config  考虑到各频道二级域名有可能进行调整,将相应配置信息存放于Web.Config文件是一个好办法。同样的,该配置信息必须同步到各Web Project。下面为配置内容:<add key="SiteDomainName" value="mysite.com"/>
<add key="HomepageSiteURL" value="http://www.mysite.com/homepage/"/>
<add key="PassportSiteURL" value="http://passport.mysite.com/passport/"/>
<add key="NewsSiteURL" value="http://news.mysite.com/news/"/>
<add key="ForumSiteURL" value="http://forum.mysite.com/forum/"/>
<add key="BlogSiteURL" value="http://blog.mysite.com/blog/"/>
<add key="LocalSiteURL" value="/blog/"/>   各配置项说明如下  SiteDomainName:站点域名,形如"mysite.com"、"mysite.com.cn"、"mysite.net"等。该配置项的使用方法将在后文引见。  LocalSiteURL:当前频道根路径,也就是Web Project所在网站或虚拟目录的路径,以"/"开头。该配置项次要用于频道内部的援用,比如图片援用、页面链接等。  其余配置项:用于频道间的援用,比如频道导航、功用调用等。  2.创建Model部件  在MVC模式组成中,Model部件包括所有的业务逻辑*作,其中也包含数据访问*作。  本方案将Model部件拆分成对象实体、对象*作以及数据访问三部分,封装成三个Class Library。  由于Class Library设计本身就是一个很大的话题,本文就不再祥述了,有兴味的话可以参考一些相关材料。 经验分享:  
  上述的Model部件拆分方式适用于业务功用比较复杂的大型项目,要求团队内部有着明确、细化的分工合作。