网站架构的设计方案-.pdf
《网站架构的设计方案-.pdf》由会员分享,可在线阅读,更多相关《网站架构的设计方案-.pdf(20页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、网站架构的设计方案1/201/20 网站架构的设计方案网站架构,一般认为是根据客户需求分析的结果,准确定位网站目标群体,设定网站整体架构,规划、设计网站栏目及其内容,制定网站开发流程及顺序,以最大限度地进行高效资源分配与管理的设计。其内容有程序架构,呈现架构,和信息架构三种表现。而步骤主要分为硬架构和软架构两步程序。网络架构是现代网络学习和发展的一个必须的基础技术。在选择机房的时候,根据网站用户的地域分布,可以选择网通或电信机房,但更多时候,可能双线机房才是合适的。越大的城市,机房价格越贵,从成本的角度看可以在一些中小城市托管服务器,比如说北京的公司可以考虑把服务器托管在天津,廊坊等地,不是特
2、别远,但是价格会便宜很多。现在的 PHP 框架有很多选择,比如:CakePHP,Symfony,Zend Framework等等,至于应该使用哪一个并没有唯一的答案,要根据 Team 里团队成员对各个框架的了解程度而定。很多时候,即使没有使用框架,一样能写出好的程序来,比如Flickr据说就是用Pear+Smarty这样的类库写出来的,所以,是否用框架,用什么框架,一般不是最重要的,重要的是我们的编程思想里要有框架的意识。网站规模到了一定的程度之后,代码里各种逻辑纠缠在一起,会给维护和扩展带来巨大的障碍,这时我们的解决方式其实很简单,那就是重构,将逻辑进行分层。通常,自上而下可以分为表现层,应
3、用层,领域层,持久层。所谓表现层,并不仅仅就指模板,它的范围要更广一些,所有和表现相关的逻辑都应该被纳入表现层的范畴。比如说某处的字体要显示为红色,某处的开头要空两格,这些都属于表现层。很多时候,我们容易犯的错误就是把本属于表现层的逻辑放到了其他层面去完成,这里说一个很常见的例子:我们在列表页显示文章标题的时候,都会设定一个最大字数,一旦标题长度超过了这个限制,就截断,并在后面显示“.”,这就是最典型的表现层逻辑,但是实际情况,有很多程序员都是在非表现层代码里完成数据的获取和截断,然后赋值给表现层模板,这样的代码最直接的缺点就是同样一段数据,在这个页面我可能想显示前10 个字,再另一个页面我可
4、能想显示前15 个字,而一旦我们在程序里固化了这个字数,也就丧失了可移植性。正确的做法是应该做一个视图助手之类的程序来专门处理此类逻辑,比如说:Smarty 里的 truncate 就属于这样的视图助手(不过它那个实现不适合中文)。所谓应用层,它的主要作用是定义用户可以做什么,并把操作结果反馈给表现层。至于如何做,通常不是它的职责范围(而是领域层的职责范围),它会通过委派把如何做的工作交给领域层去处理。在使用MVC 架构的网站中,我们可以看到类似下面这样的URL:domain/articles/view/123,其内部编码实现,一般就是一个Articles 控制器类,里面有一个view 方法,
5、这就是一个典型的应用层操作,因为它定义了用户可以做一个查看的动作。在MVC 架构中,有一个准则是这么说的:Rich Model Is Good。言外之意,就是Controller要保持“瘦”一些比较好,进而说明应用层要尽量简单,不要包括涉及领域内容的逻辑。所谓领域层,最直接的解释就是包含领域逻辑的层。它是一个软件的灵魂所在。先来网站架构的设计方案2/202/20 看看什么叫领域逻辑,简单的说,具有明确的领域概念的逻辑就是领域逻辑,比如我们在ATM 机上取钱,过程大致是这样的:插入银联卡,输入密码,输入取款金额,确定,拿钱,然后 ATM 吐出一个交易凭条。在这个过程中,银联卡在 ATM 机器里完
6、成钱从帐户上划拨的过程就是一个领域逻辑,因为取钱在银行中是一个明确的领域概念,而ATM 机吐出一个交易凭条则不是领域逻辑,而仅是一个应用逻辑,因为吐出交易凭条并不是银行中一个明确的领域概念,只是一种技术手段,对应的,我们取钱后不吐交易凭条,而发送一条提醒短信也是可能的,但并不是一定如此,如果在实际情况中,我们要求取款后必须吐出交易凭条,也就是说吐出交易凭条已经和取款紧密结合,那么你也可以把吐出交易凭条看作是领域逻辑的一部分,一切都以问题的具体情况而定。在 Eric 那本经典的领域驱动设计中,把领域层分为了五种基本元素:实体,值对象,服务,工厂,仓储。具体可以参阅书中的介绍。领域层最常犯的错误就
7、是把本应属于领域层的逻辑泄露到了其他层次,比如说在一个CMS 系统,对热门文章的定义是这样的:每天被浏览的次数多于 1000 次,被评论的次数多于100 次,这样的文章就是热门文章。对于一个 CMS 来说,热门文章这个词无疑是一个重要的领域概念,那么我们如何实现这个逻辑的设计的?你可能会给出类似下面的代码:“SELECT.FROM.WHERE 浏览 1000 AND 评论 100”,没错,这是最简单的实现方式,但是这里需要注意的是“每天被浏览的次数多于1000 次,被评论的次数多于100 次”这个重要的领域逻辑被隐藏到了 SQL 语句中,SQL 语句显然不属于领域层的范畴,也就是说,我们的领域
8、逻辑泄露了。网站的性能瓶颈分析网站的性能影响因素很多,下面主要从如下4个方面进行分析说明:1)网络负载a)公网负载b)内网负载2)WEB 应用服务器性能a)CPU b)存储,I/O访问c)内存d)并发 TCP/IP 连接数3)数据库服务器性能a)数据库参数配置b)服务器性能(CPU、内存、存储)c)数据结构的合理性网站架构的设计方案3/203/20 4)不同 WEB 应用的处理方式而对不同的性能瓶颈a)对于静态的网站:静态的 HTML 页面严格地由标准的HTML 标示语言构成,并不需要服务器端即时运算生成。这意味着,对一个静态HTML 文档发出访问请求后,服务器端只是简单地将该文档传输到客户端
9、。从服务器运行的那个时间片来看,这个传输过程仅仅占用了很小的CPU 资源。对于静态HTML 的访问瓶颈为:网络带宽、磁盘I/O以及cache(高速缓冲存储器)。b)对于动态页面因为服务器解析动态页面必须在其传输到客户端前就通过服务器来进行解释,这样就会给应用服务器添加额外的性能消耗,如果进一步要访问数据库,则会增加数据库服务器的性能消耗,则动态页面还有额外的瓶颈:应用服务器的性能,数据库服务器的性能。系统架构设计总体思路为提高网站的高并发性能,提高开发效率及运营效率,主要按如下几个思路进行规划设计:负载均衡1)四层交换负载均衡:采用负载均衡器来实现硬件级的四层交换负载均衡,或采用LVS来实现软
10、件的四层交换负载均衡。2)通过第三方软件来实现负载均衡,同时实现页面请求的缓存。通过 Nginx 实现反向代理服务器集群,同时搭建squid 集群以作为静态页面和图片的缓存。3)通过 web 服务器的配置来实现负载均衡即通过 apache 或是 Nginx 将客户请求均衡的分给tomcat1,tomcat2.去处理。网站架构的设计方案4/204/20 WEB 应用开发架构思路1)应用开发实现 MVC 架构三层架构进行web 应用开发2)页面尽可能静态化以减少动态数据访问,如果是资讯类的网站可以考虑采用第三方开源的 CMS 系统来生成静态的内容页面。3)采用 Oscache 实现页面缓存,采用
11、Memcached 实现数据缓存4)采用独立的图片服务器集群来实现图片资源的存储及WEB 请求数据存储的设计思路1)数据库拆分,把生产数据库和查询数据库分离,对生产数据库采用RAC 实现数据库的集群。2)采用高效的网络文件共享策略,采用图片服务器来实现页面的图片存储。不同网络用户访问考虑1)通过引入 CDN 来解决不同网络服务商的接入速度问题,一般只能解决静态页面的访问问题。2)在不同运营商机房部署服务器,通过镜像技术来实现不同网络服务商的接入速度问题。总体架构网站架构的设计方案5/205/20 网站的开发架构网络拓扑结构备注:Sl网站架构的设计方案6/206/20 采用双防火墙双交换机做网络
12、冗余,保障平台服务采用双防火墙通知接通2 线路互联网接入,设备之间采用VRRP 协议,在任何一个防火墙、互联网发生故障后均可自动将流量切换到另一端,保证网站的正运行,设备或网络恢复后,自动恢复。采用双千兆交换机分别接在2 台防火墙上,当某台设备或者网络链路发生故障后,好设备自动接管已坏设备的工作,不影响网站的整体运行,根据业务及真实服务器的数量,交换机可以随时增加。采用硬件设备负载均衡器,实现网络流量的负载均衡使用硬件设备负载均衡器,将网络流量均衡的分担到WEB 服务器集群各节点服务器,保障平台服务器资源均衡的使用。采用代理服务器,实现软件级的网络负载均衡。数据库服务器分离成生产数据库集群和查
13、询数据库集群,实现生产读写与后台查询统计进行分离,同时生产数据库采用rac 技术进行架构涉及技术的详解负载均衡基于 DNS 的负载均衡-一个域名绑定多个IP DNS 负载均衡技术是最早的负载均衡解决方案,它是通过DNS 服务中的随机名字解析来实现的,在DNS 服务器中,可以为多个不同的地址配置同一个名字,而最终查询这个名字的客户机将在解析这个名字时得到其中的一个地址。因此,对于同一个名字,不同的客户机会得到不同的地址,它们也就访问不同地址上的 Web 服务器,从而达到负载均衡的目的。这种技术的优点是,实现简单、实施容易、成本低、适用于大多数TCP/IP应用;但是,其缺点也非常明显,首先这种方案
14、不是真正意义上的负载均衡,DNS 服务器将Http 请求平均地分配到后台的Web服务器上,而不考虑每个Web 服务器当前的负载情况;如果后台的Web 服务器的配置和处理能力不同,最慢的Web服务器将成为系统的瓶颈,处理能力强的服务器不能充分发挥作用;其次未考虑容错,如果后台的某台Web 服务器出现故障,DNS 服务器仍然会把 DNS 请求分配到这台故障服务器上,导致不能响应客户端。最后一点是致命的,有可能造成相当一部分客户不能享受Web 服务,并且由于DNS 缓存的原因,所造成的后果要持续相当长一段时间(一般 DNS 的刷新周期约为24 小时)。所以在国外最新的建设中心Web 站点方案中,已经
15、很少采用这种方案了。通过硬件四层交换实现负载均衡在硬件四层交换产品领域,有一些知名的产品可以选择,比如Alteon、F5等,这些产品很昂贵,但是物有所值,能够提供非常优秀的性能和很灵活的管理能力。Yahoo 中国当初接近2000 台服务器使用了三四台Alteon 就搞定了通过软件四层交换实现负载均衡软件四层交换我们可以使用Linux 上常用的LVS 来解决,LVS 就是 Linux 网站架构的设计方案7/207/20 Virtual Server,他提供了基于心跳线heartbeat的实时灾难应对解决方案,提高系统的鲁棒性,同时可供了灵活的虚拟VIP 配置和管理功能,可以同时满足多种应用需求,
16、这对于分布式的系统来说必不可少。一个典型的使用负载均衡的策略就是,在软件或者硬件四层交换的基础上搭建 squid 集群,这种思路在很多大型网站包括搜索引擎上被采用,这样的架构低成本、高性能还有很强的扩张性。通过反向代理服务器实现负载均衡反向代理服务器又称为WEB 加速服务器,它位于WEB 服务器的前端,充当 WEB 服务器的内容缓存器,反向代理服务器是针对WEB 服务器设置的,后台WEB 服务器对互联网用户是透明的,用户只能看到反向代理服务器的地址,不清楚后台WEB 服务器是如何组织架构的。当互联网用户请求WEB 服务时,DNS 将请求的域名解析为反向代理服务器的IP 地址,这样URL 请求将
17、被发送到反向代理服务器,由反向代理服务器负责处理用户的请求与应答、与后台WEB 服务器交互。利用架构涉及技术的详解负载均衡基于 DNS 的负载均衡-一个域名绑定多个IP DNS 负载均衡技术是最早的负载均衡解决方案,它是通过DNS 服务中的随机名字解析来实现的,在DNS 服务器中,可以为多个不同的地址配置同一个名字,而最终查询这个名字的客户机将在解析这个名字时得到其中的一个地址。因此,对于同一个名字,不同的客户机会得到不同的地址,它们也就访问不同地址上的 Web 服务器,从而达到负载均衡的目的。这种技术的优点是,实现简单、实施容易、成本低、适用于大多数TCP/IP应用;但是,其缺点也非常明显,
18、首先这种方案不是真正意义上的负载均衡,DNS 服务器将Http 请求平均地分配到后台的Web服务器上,而不考虑每个Web 服务器当前的负载情况;如果后台的Web 服务器的配置和处理能力不同,最慢的Web服务器将成为系统的瓶颈,处理能力强的服务器不能充分发挥作用;其次未考虑容错,如果后台的某台Web 服务器出现故障,DNS 服务器仍然会把 DNS 请求分配到这台故障服务器上,导致不能响应客户端。最后一点是致命的,有可能造成相当一部分客户不能享受Web 服务,并且由于DNS 缓存的原因,所造成的后果要持续相当长一段时间(一般 DNS 的刷新周期约为24 小时)。所以在国外最新的建设中心Web 站点
19、方案中,已经很少采用这种方案了。通过硬件四层交换实现负载均衡在硬件四层交换产品领域,有一些知名的产品可以选择,比如Alteon、F5等,这些产品很昂贵,但是物有所值,能够提供非常优秀的性能和很灵活的管理能力。Yahoo 中国当初接近2000 台服务器使用了三四台Alteon 就搞定了通过软件四层交换实现负载均衡软件四层交换我们可以使用Linux 上常用的LVS 来解决,LVS 就是 Linux Virtual Server,他提供了基于心跳线heartbeat的实时灾难应对解决方案,提高系统的鲁棒性,同时可供了灵活的虚拟VIP 配置和管理功能,可以同时满足多种应用需求,这对于分布式的系统来说必
20、不可少。一个典型的使用负载均衡的策略就是,在软件或者硬件四层交换的基础上网站架构的设计方案8/208/20 搭建 squid 集群,这种思路在很多大型网站包括搜索引擎上被采用,这样的架构低成本、高性能还有很强的扩张性。通过反向代理服务器实现负载均衡反向代理服务器又称为WEB 加速服务器,它位于WEB 服务器的前端,充当 WEB 服务器的内容缓存器,反向代理服务器是针对WEB 服务器设置的,后台WEB 服务器对互联网用户是透明的,用户只能看到反向代理服务器的地址,不清楚后台WEB 服务器是如何组织架构的。当互联网用户请求WEB 服务时,DNS 将请求的域名解析为反向代理服务器的IP 地址,这样U
21、RL 请求将被发送到反向代理服务器,由反向代理服务器负责处理用户的请求与应答、与后台WEB 服务器交互。利用反向代理服务器减轻了后台WEB 服务器的负载,提高了访问速度,同时避免了因用户直接与WEB 服务器通信带来的安全隐患。主防火精.a耻J!J圃,l.Q ii 阻,嚣,晨,臣费蛐 fRRP 冒冒固自凰”霉憬”嚣,民嚣1II,撮,备防火淄备交换饥.且帽跑嗣盟2代理服务嚣良静同瞌剧铸跑集醉剧院!l!量集酣应用凰务量集群生.JI地m罪S集创E弯lRjll务植嗣s,h电 3章侨茸帆锺盘到i列祖E磁盘醉列把”精鲤峭网站架构的设计方案9/209/20 目前有许多反向代理软件,比较有名的有Nginx 和
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 网站 架构 设计方案
限制150内