版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、.wd.wd.wd.前台门户网站架构设计方案北京宽连十方数字技术2012-7目 录TOC o 1-3 h z uHYPERLINK l _Toc2676444881设计思路 PAGEREF _Toc267644488 h 3HYPERLINK l _Toc2676444892系统构造 PAGEREF _Toc267644489 h 3HYPERLINK l _Toc2676444903网络规划及性能计算 PAGEREF _Toc267644490 h 3HYPERLINK l _Toc2676444913.1网络架构 PAGEREF _Toc267644491 h 3HYPERLINK l _
2、Toc2676444923.2网络架构说明 PAGEREF _Toc267644492 h 4HYPERLINK l _Toc2676444933.2.1采用双防火墙双交换机做网络冗余,保障平台服务 PAGEREF _Toc267644493 h 4HYPERLINK l _Toc2676444943.2.2采用硬件设备负载均衡器,实现网络流量的负载均衡 PAGEREF _Toc267644494 h 4HYPERLINK l _Toc2676444953.3系统测算 PAGEREF _Toc267644495 h 4HYPERLINK l _Toc2676444963.3.1系统处理能力要求
3、 PAGEREF _Toc267644496 h 4HYPERLINK l _Toc2676444973.3.2业务处理能力要求 PAGEREF _Toc267644497 h 4HYPERLINK l _Toc2676444983.3.3系统话务模型 PAGEREF _Toc267644498 h 4HYPERLINK l _Toc2676444993.4配置核算 PAGEREF _Toc267644499 h 5HYPERLINK l _Toc2676445003.4.1数据库服务器性能核算 PAGEREF _Toc267644500 h 5HYPERLINK l _Toc26764450
4、13.4.2WEB服务器集群性能核算 PAGEREF _Toc267644501 h 5HYPERLINK l _Toc2676445023.4.3WEB服务器集群内存性能核算 PAGEREF _Toc267644502 h 5HYPERLINK l _Toc2676445033.4.4网络带宽 PAGEREF _Toc267644503 h 5HYPERLINK l _Toc2676445044性能模拟测试及性能推算 PAGEREF _Toc267644504 h 6HYPERLINK l _Toc2676445054.1测试环境 PAGEREF _Toc267644505 h 6HYPER
5、LINK l _Toc2676445064.2测试结果 PAGEREF _Toc267644506 h 8HYPERLINK l _Toc2676445074.2.11个客户端模拟不同线和并发请求结果 PAGEREF _Toc267644507 h 8HYPERLINK l _Toc2676445084.2.210个客户端请求 PAGEREF _Toc267644508 h 8HYPERLINK l _Toc2676445094.3结果分析 PAGEREF _Toc267644509 h 9HYPERLINK l _Toc2676445104.4根据测试结果推算 PAGEREF _Toc267
6、644510 h 9HYPERLINK l _Toc2676445114.5设备清单 PAGEREF _Toc267644511 h 11HYPERLINK l _Toc2676445124.5.1硬件设备配置清单 PAGEREF _Toc267644512 h 11HYPERLINK l _Toc2676445134.5.2设备技术规格 PAGEREF _Toc267644513 h 12HYPERLINK l _Toc2676445144.6平台扩容的建议 PAGEREF _Toc267644514 h 12网站的性能瓶颈分析网站的性能影响因素很多,下面主要从如下4个方面进展分析说明:网络
7、负载公网负载内网负载WEB应用服务器性能CPU存储,I/O访问内存并发TCP/IP连接数数据库服务器性能数据库参数配置服务器性能CPU、内存、存储数据构造的合理性不同WEB应用的处理方式而对不同的性能瓶颈对于静态的网站:静态的HTML页面严格地由标准的HTML标示语言构成,并不需要服务器端即时运算生成。这意味着,对一个静态HTML文档发出访问请求后,服务器端只是简单地将该文档传输到客户端。从服务器运行的那个时间片来看,这个传输过程仅仅占用了很小的CPU资源。对于静态HTML的访问瓶颈为:网络带宽、磁盘I/O以及cache(高速缓冲存储器)。对于动态页面因为服务器解析动态页面必须在其传输到客户端
8、前就通过服务器来进展解释,这样就会给应用服务器添加额外的性能消耗,如果进一步要访问数据库,那么会增加数据库服务器的性能消耗,那么动态页面还有额外的瓶颈:应用服务器的性能,数据库服务器的性能。系统架构设计总体思路为提高网站的高并发性能,提高开发效率及运营效率,主要按如下几个思路进展规划设计:负载均衡四层交换负载均衡:采用负载均衡器来实现硬件级的四层交换负载均衡,或采用LVS来实现软件的四层交换负载均衡。通过第三方软件来实现负载均衡,同时实现页面请求的缓存。通过Nginx实现反向代理服务器集群,同时搭建squid集群以作为静态页面和图片的缓存。通过web服务器的配置来实现负载均衡即通过apache
9、或是Nginx 将客户请求均衡的分给tomcat1,tomcat2去处理。WEB应用开发架构思路应用开发实现MVC架构三层架构进展web应用开发页面尽可能静态化以减少动态数据访问,如果是资讯类的网站可以考虑采用第三方开源的CMS系统来生成静态的内容页面。采用Oscache实现页面缓存,采用Memcached实现数据缓存采用独立的图片服务器集群来实现图片资源的存储及WEB请求数据存储的设计思路数据库拆分,把生产数据库和查询数据库别离,对生产数据库采用RAC实现数据库的集群。采用高效的网络文件共享策略,采用图片服务器来实现页面的图片存储。不同网络用户访问考虑通过引入CDN来解决不同网络服务商的接入
10、速度问题,一般只能解决静态页面的访问问题。在不同运营商机房部署服务器,通过镜像技术来实现不同网络服务商的接入速度问题。总体架构网站的系统分层架构网站的物理架构网站的开发架构网络拓扑构造备注:采用双防火墙双交换机做网络冗余,保障平台服务采用双防火墙通知接通2线路互联网接入,设备之间采用VRRP协议,在任何一个防火墙、互联网发生故障后均可自动将流量切换到另一端,保证网站的正运行,设备或网络恢复后,自动恢复。采用双千兆交换机分别接在2台防火墙上,当某台设备或者网络链路发生故障后,好设备自动接收已坏设备的工作,不影响网站的整体运行,根据业务及真实服务器的数量,交换机可以随时增加。采用硬件设备负载均衡器
11、,实现网络流量的负载均衡使用硬件设备负载均衡器,将网络流量均衡的分担到WEB服务器集群各节点服务器,保障平台服务器资源均衡的使用。采用代理服务器,实现软件级的网络负载均衡。数据库服务器别离成生产数据库集群和查询数据库集群,实现生产读写与后台查询统计进展别离,同时生产数据库采用rac技术进展架构涉及技术的详解负载均衡基于DNS的负载均衡-一个域名绑定多个IPDNS负载均衡技术是最早的负载均衡解决方案,它是通过DNS服务中的随机名字解析来实现的,在DNS服务器中,可以为多个不同的地址配置同一个名字,而最终查询这个名字的客户机将在解析这个名字时得到其中的一个地址。因此,对于同一个名字,不同的客户时机
12、得到不同的地址,它们也就访问不同地址上的Web 服务器,从而到达负载均衡的目的。这种技术的优点是,实现简单、实施容易、成本低、适用于大多数TCP/IP应用;但是,其缺点也非常明显,首先这种方案不是真正意义上的负载均衡,DNS 服务器将 请求平均地分配到后台的Web服务器上,而不考虑每个Web服务器当前的负载情况;如果后台的Web服务器的配置和处理能力不同,最慢的 Web服务器将成为系统的瓶颈,处理能力强的服务器不能充分发挥作用;其次未考虑容错,如果后台的某台Web服务器出现故障,DNS服务器仍然会把DNS 请求分配到这台故障服务器上,导致不能响应客户端。最后一点是致命的,有可能造成相当一局部客
13、户不能享受Web服务,并且由于DNS缓存的原因,所造成的后果要持续相当长一段时间(一般DNS的刷新周期约为24小时)。所以在国外最新的建设中心Web站点方案中,已经很少采用这种方案了。通过硬件四层交换实现负载均衡在硬件四层交换产品领域,有一些知名的产品可以选择,比方Alteon、F5等,这些产品很昂贵,但是物有所值,能够提供非常优秀的性能和很灵活的管理能力。Yahoo中国当初接近2000台服务器使用了三四台Alteon就搞定了通过软件四层交换实现负载均衡软件四层交换我们可以使用Linux上常用的LVS来解决,LVS就是Linux Virtual Server,他提供了基于心跳线heartbea
14、t的实时灾难应对解决方案,提高系统的鲁棒性,同时可供了灵活的虚拟VIP配置和管理功能,可以同时满足多种应用需求,这对于分布式的系统来说必不可少。一个典型的使用负载均衡的策略就是,在软件或者硬件四层交换的根基上搭建squid集群,这种思路在很多大型网站包括搜索引擎上被采用,这样的架构低成本、高性能还有很强的扩张性。通过反向代理服务器实现负载均衡反向代理服务器又称为 WEB 加速服务器,它位于 WEB 服务器的前端,充当WEB服务器的内容缓存器,反向代理服务器是针对 WEB 服务器设置的,后台 WEB 服务器对互联网用户是透明的,用户只能看到反向代理服务器的地址,不清楚后台 WEB 服务器是如何组
15、织架构的。当互联网用户请求 WEB 服务时,DNS 将请求的域名解析为反向代理服务器的 IP 地址,这样 URL 请求将被发送到反向代理服务器,由反向代理服务器负责处理用户的请求与应答、与后台 WEB 服务器交互。利用反向代理服务器减轻了后台 WEB 服务器的负载,提高了访问速度,同时防止了因用户直接与 WEB 服务器通信带来的安全隐患。目前有许多反向代理软件,比较有名的有 Nginx 和 Squid 。Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,是一个高性能的 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。Squi
16、d是由美国政府大力资助的一项研究方案,其目的为解决网络带宽缺乏的问题,支持 , S,FTP 等多种协议,是现在 Unix 系统上使用、最多功能也最完整的一套软体。Squid Squid 是一个开源的软件,利用它的反向代理技术可以提高网站系统的访问速度,下面将重点介绍 Squid 反向代理的实现原理和在提高网站性能方面的应用。Squid反向代理服务器位于本地 WEB 服务器和 Internet 之间 , 组织架构如以以下图:客户端请求访问 WEB 服务时,DNS 将访问的域名解析为 Squid 反向代理服务器的 IP 地址,这样客户端的 URL 请求将被发送到反向代理服务器。如果 Squid 反
17、向代理服务器中缓存了该请求的资源,那么将该请求的资源直接返回给客户端,否那么反向代理服务器将向后台的 WEB 服务器请求资源,然后将请求的应答返回给客户端,同时也将该应答缓存在本地,供下一个请求者使用。Squid 反向代理一般只缓存可缓冲的数据比方 html 网页和图片等,而一些 CGI 脚本程序或者 ASP、JSP 之类的动态程序默认不缓存。它根据从 WEB 服务器返回的 头标记来缓冲静态页面, 有四个最重要 头标记:Last-Modified: 告诉反向代理页面什么时间被修改Expires: 告诉反向代理页面什么时间应该从缓冲区中删除Cache-Control: 告诉反向代理页面是否应该被
18、缓冲Pragma: 用来包含实现特定的指令,最常用的是 Pragma:no-cache 注:DNS 的轮询机制将某一个域名解析为 多个IP地址。NginxNginx (“engine x) 是俄罗斯人Igor Sysoev(塞索耶夫)编写的一款高性能的 和反向代理服务器。Nginx 已经在俄罗斯最大的门户网站 Rambler Media rambler.ru上运行了4年时间,同时俄罗斯超过20%的虚拟主机平台采用Nginx作为反向代理服务器。在国内,已经有新浪博客、新浪播客、搜狐通行证、网易新闻、网易博客、金山逍遥网、金山爱词霸、校内网、YUPOO相册、豆瓣、迅雷看看等多家网站、频道使用 Ng
19、inx 服务器。Nginx 特点如下:工作在OSI模型的第7层应用层高并发连接官方测试能够支撑5万并发连接,在实际生产环境中跑到23万并发连接数。 内存消耗少在3万并发连接下,开启的10个Nginx 进程才消耗150M内存15M*10=150M。 配置文件非常简单风格跟程序一样通俗易懂。 成本低廉Nginx为开源软件,可以免费使用。而购置F5 BIG-IP、NetScaler等硬件负载均衡交换机那么需要十多万至几十万人民币。 支持Rewrite重写规那么能够根据域名、URL的不同,将 请求分到不同的后端服务器群组。 内置的安康检查功能如果 Nginx Proxy 后端的某台 Web 服务器宕机
20、了,不会影响前端访问。 节省带宽支持 GZIP 压缩,可以添加浏览器本地缓存的 Header 头。 稳定性高用于反向代理,宕机的概率微乎其微。 Nginx+squid页面缓存来实现反向代理负载均衡通过Nginx反向代理和squid缓存实现动静别离的架构图如下所示:Apache +tomcat集群实现负载均衡。使用 apache和多个tomcat 配置一个可以应用的web网站,用Apache进展分流,把请求按照权重以及当时负荷分tomcat1,tomcat2.去处理,要到达以下要求:Apache 做为 Server ,通过mod_jk连接器连接多个 tomcat 应用实例,并进展负载均衡。同时还
21、要配置session复制,也就是说其中任何一个tomcat的添加的session,是要同步复制到其它tomcat, 集群内的tomcat都有一样的session,并为系统包括 Apache 和 tomcat设定 Session 超时时间。缓存系统架构方面的缓存Squid缓存架构方面使用Squid进展缓存。注:SQUID使用了LM算法,LM就是页面Header里时间(Date)和Last-Modified时间的差。Date一般是Squid从后面取页面的时间,Last-Modified 一般是页面生成时间。Nginx的缓存功能Nginx从0.7.48版本开场,支持了类似Squid的缓存功能;缓存把
22、URL及相关组合当作Key,用md5编码哈希后保存;Nginx的Web缓存服务只能为指定URL或状态码设置过期时间,不支持类似Squid的PURGE指令,手动去除指定缓存页面;采用MMAP实现,设置的缓存区大小不能超过物理内存+SWEB的值基于mem HYPERLINK :/ jzxue /tag/cache/ t _blank cached的缓存nginx对 HYPERLINK :/ jzxue /tag/memcache/ t _blank memcached有所支持,但是功能并不是特别之强,性能上还是非常之优秀。location /mem/ if ( $uri /mem/(0-9A-Za
23、-z_*)$ ) set $memcached_key $1; memcached_pass :11211; expires 70;这个配置会将 :/sudone /mem/abc指明到memcached的abc这个key去取数据。Nginx目前没有写入memcached的任何机制,所以要往memcached里写入数据得用后台的动态语言完成,可以利用404定向到后端去写入数据。Nginx传统缓存的缺点也是它和squid等缓存软件的不同之特色,所以也可看作其优点。在生产应用中它常常用作和squid的伙伴,squid对于带?的链接往往无法阻挡,而nginx能将其访问拦住,例如: :/sudone
24、/?和 :/sudone /在squid上会被当做两个链接,所以会造成两次穿透;而nginx只会保存一次,无论链接变成 :/sudone /?1还是 :/sudone /?123,均不能透过nginx缓存,从而有效地保护了后端主机。nginx会非常老实地将链接形式保存到文件系统中,这样对于一个链接,可以很方便地查阅它在缓存机器上的缓存状态和内容,也可以很方便地和别的文件管理器如rsync等配合使用,它完完全全就是一个文件系统构造。应用程序方面的缓存OSCacheOSCache由OpenSymphony设计,它是一种开创性的JSP定制标记应用,提供了在现有JSP页面之内实现快速内存缓冲的功能,O
25、SCache是个一个广泛采用的高性能的J2EE缓存框架,OSCache能用于任何Java应用程序的普通的缓存解决方案。OSCache有以下特点:缓存任何对象,你可以不受限制的缓存局部jsp页面或 请求,任何java对象都可以缓存。拥有全面的API-OSCache API给你全面的程序来控制所有的OSCache特性。永久缓存-缓存能随意的写入硬盘,因此允许昂贵的创立expensive-to-create数据来保持缓存,甚至能让应用重启。支持集群-集群缓存数据能被单个的进展参数配置,不需要修改代码。缓存记录的过期-你可以有最大限度的控制缓存对象的过期,包括可插入式的刷新策略如果默认性能不需要时。O
26、SCache是当前运用最广的缓存方案,JBoss,Hibernate,Spring等都对其有支持。OSCache的特点:1) 缓存任何对象:你可以不受限制的缓存局部jsp页面或 请求,任何java对象都可以缓存。 2) 拥有全面的API:OSCache API允许你通过编程的方式来控制所有的OSCache特性。 3) 永久缓存:缓存能被配置写入硬盘,因此允许在应用服务器的屡次生命周期间缓存创立开销昂贵的数据。 4) 支持集群:集群缓存数据能被单个的进展参数配置,不需要修改代码。 5) 缓存过期:你可以有最大限度的控制缓存对象的过期,包括可插入式的刷新策略如果默认性能不能满足需要时。Memcac
27、hedmemcached是高性能的分布式内存缓存服务器。一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度、 提高可扩展性。Memcached是以Key/Value的形式单个对象缓存。自主开发的内存数据缓存服务独立进程方式的缓存服务对于一些常用的动态数据通过开发程序服务缓存在内存中,提供给其他子系统调用,如下面的数据就可以通过这样方式进展缓存。用户 基本信息及状态的信息缓冲列表缓存,就像论坛里帖子的列表记录条数的缓存,比方一个论坛板块里有多少个帖子,这样才方便实现分页。复杂一点的group,sum,count查询,比方积分的分类排名集成在WEB应用中的内存
28、缓存在web应用中对于热点的功能,考虑使用完全装载到内存,保证绝对的响应速度,对于需要频繁访问的热点数据,采用集中缓存(多个可以采用负载均衡),减轻数据库的压力,比方:很多配置信息,操作员信息等等。页面静态化静态的HTML页面严格地由标准的HTML标示语言构成,并不需要服务器端即时运算生成。这意味着,对一个静态HTML文档发出访问请求后,服务器端只是简单地将该文档传输到客户端。从服务器运行的那个时间片来看,这个传输过程仅仅占用了很小的CPU资源。页面静态化就是采用效率最高、消耗最小的纯静态化的html页面来替换动态页面。我们尽可能使我们的网站上的页面采用静态页面来实现,这个最简单的方法其实也是
29、最有效的方法。同时采用第三方开源的CMS系统来实现网站内容的管理。对于大量内容并且频繁更新的网站,我们无法全部手动去挨个实现页面静态化,所以我们需要引入常见的信息发布系统(CMS),信息发布系统(CMS)可以实现最简单的信息录入自动生成静态页面,对于一个大型网站来说,拥有一套高效、可管理的CMS是必不可少的。同时,HTML静态化也是某些缓存策略使用的手段,对于系统中频繁使用数据库查询但是内容更新很小的应用,可以考虑使用HTML静态化来实现,比方论坛中论坛的公用设置信息,这些信息目前的主流论坛都可以进展后台管理并且 HYPERLINK :/storage.it168 / o 存储 t _blan
30、k 存储再数据库中,这些信息其实大量被前台程序调用,但是更新频率很小,可以考虑将这局部内容进展后台更新的时候进展静态化,这样防止了大量的数据库访问请求。在进展html静态化的时候还可以使用一种折中的方法,就是前端继续使用动态实现,在一定的策略下通过后台模块进展定时把动态网页生成静态页面,并定时判断调用,这个能实现很多灵活性的操作。为了提高静态HTML的访问效率,主要可以对以下几个方面进展优化:网络带宽、磁盘I/O以及cache(高速缓冲存储器)。数据库配置及优化数据库集群对生产数据库采用RAC实现数据库的集群。数据库及表的散列把生产数据库和查询数据库进展别离,针对系统业务数据的特点,把大的表进
31、展拆分,对于访问较多的表采用分区表。使用读/写数据库别离,随着系统变得越来越庞大,特别是当它们拥有 很差的SQL时,一台数据库服务器通常缺乏以处理负载。但是多个数据库意味着重复,除非你对数据进展了别离。更一般地,这意味着建设主/从副本系统,其中 程序会对主库编写所有的Update、Insert和Delete变更语句,而所有Select的数据都读取自从数据库或者多个从数据库。尽管概念上很简单,但是想要合理、准确地实 现并不容易,这可能需要大量的代码工作。因此,即便在开场时使用同一台数据库服务器,也要尽早方案在PHP中使用别离的DB连接来进展读写操作。如果正确 地完成该项工作,那么系统就可以扩展到
32、2台、3台甚至12台服务器,并具备高可用性和稳定性。拥有良好的DB配置和备份很多公司都没有良好的备份机制,也不知道如 何恰当地完成这项工作。只有imp是不够的,还需要进展热备份,从而得到超快的速度和超高的可靠性。另外,在将所有备份文件从服务器上转移出来之前要进展压缩和加密。另外还要确保拥有设计合理的、有用的关于安全、性能和稳定性问题的设定,包括防止数据败坏,其中很多设定都是非常重要的。文件存储文件共享HDFSGFSHDFS是Apache Hadoop工程中的一个分布式文件系统实现,基于Google于2003年10月发表的Google File System(GFS)论文。特性硬件要求低高容错性
33、易可扩展配置简单超大文件HDFS采用master/slave架构。一个HDFS集群是由一个Namenode和一定数目的Datanodes组成。NFS与GFS比较首先从它们的功能上进展分析。NFS即网络文件系统,是由SUN公司开发的。它是FreeBSD支持的文件系统中的一种,允许一个系统在网络上与它人共享目录和文件。通过使用NFS,用户和程序访问远端系统上的文件就像访问本地文件一样。而GFS是Google为了满足本公司迅速增长的数据处理要求而开发的文件系统。GFS是一个可扩展的分布式文件系统,用于大型的、分布式的、对大量数据进展访问的应用。它是针对Google的计算机集群进展设计的,专门是为Go
34、ogle页面搜索的存储进展了优化。所以从功能上看,它们两者是完全不同的概念。其次从构造上比较,NFS至少包括两个主要局部:一台服务器,以及至少一台客户机。被共享的目录和文件存放在服务器上,客户机远程地访问保存在服务器上的数据。GFS那么由一台Master(通常有几台备份)和假设干台TrunkServer构成。GFS中文件备份成固定大小的Trunk分别存储在不同的 TrunkServer上,每个Trunk有多份(比方3)拷贝,也存储在不同的TrunkServer上。Master负责维护GFS中的 Metadata,即文件名及其Trunk信息。客户端先从Master上得到文件的Metadata,根
35、据要读取的数据在文件中的位置与相应的 TrunkServer通信,获取文件数据。再从跨平台性上,NFS的 基本原那么是“容许不同的客户端及服务端通过一组RPCs分享一样的文件系统,它是独立于操作系统的,容许不同的操作系统共同地进展文件的共享。而GFS那么没有这一特点,文件只能被集群系统中的PC所访问,而且这些PC的操作系统一般是Linux。最后从规模上比较,HDFS只应用在大批量的数据共享上。目前Google拥有超过200个的GFS集群,其中有些集群的PC数量超过5000台。集群的数据存储规模可以到达5个PB,并且集群中的数据读写吞吐量可到达每秒40G。而NFS一般没有这么巨大的规模。文件的多
36、服务器自动同步使用Linux 2.6内核的inotify监控Linux文件系统事件。利用开源的lsync监听某一目录,如果目录内文件发生增、删、改,利用Rsync协议自动同步到多台服务器。图片服务器别离特别是如果程序与图片都放在同一个 APAHCE 的服务器下,每一个图片的请求都有可能导致一个 D 进程的调用。使用独立的图片服务器不但可以防止以上这个情况,更可以对不同的使用性质的图片设置不同的过期时间,以便同一个用户在不同页面访问一样图片时不会再次从服务器基于是缓存服务器取数据,不但快速,而且还省了带宽。还有就是,对于缓存的时间上,亦可以做独立的调节。网络问题解决方案你不可能要求所有的使用人员
37、,都和你的服务器在一个运营商的网络内,而不同网络之间访问速度会很慢,我们可以采用镜像网站和引入CDN来解决这一问题。智能DNS解析我们可以在不同的网络运营商部署web服务器,通过linux上的rsync工具自动同步到不同网络接入商的web服务器上,以作为主站的镜像。然后通过配置智能DNS解析来引导不同网络的访问用户到对应的网络运营商的web服务器。CDN如果有足够的投资,也可以采用CDN(内容分发网),把静态内容静态页面和图片进展CDN缓存,以减轻服务器压力。CDN的全称是Content Delivery Network,即内容分发网络。它采取了分布式网络缓存构造即国际上流行的web cach
38、e技术,其目的是通过在现有的Internet中增加一层新的网络架构,将网站的内容发布到最接近用户的网络边缘,使用户可以就近取得所需的内容,解决 Internet网络拥挤的状况,提高用户访问网站的响应速度。从技术上全面解决由于网络带宽小、用户访问量大、网点分布不均等原因所造成的用户访问网站响应速度慢的问题。 (也就是一个服务器的内容,平均分部到多个服务器上,服务器智能识别,让用户获取离用户最近的服务器,提高速度。目前,国内访问量较高的大型网站如新浪、网易等,均使用CDN网络加速技术,虽然网站的访问巨大,但无论在什么地方访问都会感觉速度很快。而一般的网站如果服务器在网通,电信用户访问很慢,如果服务
39、器在电信,网通用户访问又很慢。WEB应用开发架构设计思路基于MVC的三层应用开发架构应用开发实现MVC三层架构进展web应用开发,采用ibatis作为持久层框架,c3p0作为数据库连接池。iBATIS 是一个可以设计和实现更好的 Java 应用程序持久化层的框架。iBATIS 把对象和存储过程或者使用 XML 描述符的 SQL 语句进展了关联。简单是 iBATIS 最大的优势ibatis-使用ibatis的十个理由1. 至少能操作10种以上的数据库2. 可配置的caching(包括附属)3. 支持DataSource、local transaction managemen和global tra
40、nsaction4. 简单的XML配置文档5. 支持Map, Collection, List和简单类型包装(如Integer, String)6. 支持JavaBeans类(get/set 方法)7. 支持复杂的对象映射(如populating lists, complex object models)8. 对象模型从不完美(不需要修改)9. 数据模型从不完美(不需要修改)10. 你已经知道SQL,为什么还要学习其他东西MVC架构示意Struts架构客户端发送一个 请求,通过Struts框架最后获得一个 响应,这一过程非常重要,它是理解Struts框架的重点。上图描述了Struts框架的构造
41、,而以以下图通过一个活动图更具体描述承受请求直至返回响应的整个过程:面向服务的应用架构面向服务的应用架构是指构建可分布式的、去中心化的服务器平台,以提供许多不同的应用,数据库被分成很多个小局部,围绕每个局部都会创立一个服务接口(API),并且该接口是访问数据库的唯一途径。最终数据库演变成一个非常庞大的共享资源。这种架构是松散耦合的,并且围绕着服务进展构建。面向服务的架构提供给他们隔离特性,一个服务可能有很多台数据库服务器,他们之间的数据是相通的,而对外他们的接口只有一个,外面是无法知道这个服务后面的数据组织是如何搭建的。这样就有了越来越多的应用服务器。这些应用服务器从数据众多的服务每个服务背后
42、都有数据库或集群数据库中聚合信息,然后生成我们所看到的Amazon 的各个网站页面。这样各种服务如插件一样组成了一个开放的平台,这样团队的规模就会比较小,比较灵活。注Amazon就是采用了这种架构来构 建的,它拥有上千台服务器。系统软件参数优化在一定的架构根基上,要提高并发处理能力那么需要调整服务器的操作系统内核参数、web服务器tomcat的参数、apache的参数、Nginx的参数,以使其性能到达最优化。操作系统优化调整系统的内核参数,增大连接数及TCP/IP的超时设置。Linux系统中:在/etc/sysctl.conf配置文件中增加如下内核参数:net.ipv4.tcp_syncook
43、ies = 1net.ipv4.tcp_tw_reuse = 1net.ipv4.tcp_tw_recycle = 1net.ipv4.tcp_fin_timeout = 5tomcat服务器优化增大并发连接数,调整内存参数的设置。1、JDK内存优化:当应用程序需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃。因此一般建议堆的最大值设置为可用内存的最大值的80%。 Tomcat默认可以使用的内存为128MB,在较大型的应用工程中,这点内存是不够的,需要调大.Tomcat默认可以使用的内存为128MB,Windows下,在文件/bin/catalina.bat,Unix下,
44、在文件/bin/catalina.sh的前面,增加如下设置: JAVA_OPTS=-Xms【初始化内存大小】 -Xmx【可以使用的最大内存】 需要把这个两个参数值调大。例如: JAVA_OPTS=-Xms256m -Xmx512m 表示初始化内存为256MB,可以使用的最大内存为512MB。2、连接器优化: 在tomcat配置文件server.xml中的配置中,和连接数相关的参数有:maxThreads: Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创立的最大的线程数。默认值150。acceptCount: 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列
45、中的请求数,超过这个数的请求将不予处理。默认值10。minSpareThreads: Tomcat初始化时创立的线程数。默认值25。maxSpareThreads: 一旦创立的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值75。enableLookups: 是否反查域名,默认值为true。为了提高处理能力,应设置为falseconnnectionTimeout: 网络连接超时,默认值60000,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。maxKeepAliveRequests: 保持请求数量,默认值100。 bufferSize:
46、输入流缓冲大小,默认值2048 pression: 压缩传输,取值on/off/force,默认值off。 其中和最大连接数相关的参数为maxThreads和acceptCount。如果要加大并发连接数,应同时加大这两个参数。web server允许的最大连接数还受制于*作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。apache服务器优化加大并发数量和关闭不需要的模块。因为apache非常消耗内存,尽量轻量化。Apache在配置ContentType的时候可以尽量少支持,尽可能少的LoadModule,保证更高的系统消耗和执行效率同时配
47、置apache和tomcat的组合使之能作到动静别离,apache处理静态页面,tomcat处理动态页面。在处理静态页面或者图片、js等访问方面,可以考虑使用 HYPERLINK :/ lig lig d代替Apache,它提供了更轻量级和更高效的处理能力Nginx服务器的优化worker_processes:该参数的值最好跟cpu核数相等,能够发挥最大性能,如果nginx所在服务器为2颗双核cpu,那么建议设定为4。Web服务架构评测主要对基于tomcat和nginx+tomcat的web服务器的处理性能进展测试,以作为不同性能要求下架构选型的依据测试环境网络环境内网带宽千M内网。内网pin
48、g包延迟:15082秒12986条/秒106万从第82秒开场,tomcat占用内存1.1g,但CPU资源被tomcat耗尽,服务器负载急剧升高,top显示已达150,服务器停顿响应客户端请求,客户端请求速度急剧下降,错包率100%,测试被迫中断。22500200万25毫秒Test11.7G6%,且仍在增加,测试终止。tomcat抛出“java.lang.OutOfMemoryError: GC overhead limit exceeded “异常。Test2293秒4123条/秒120万32500200万50毫秒Test11.7G 3422秒2863条/秒120万服务端从第400秒左右开场,
49、tomcat占用内存到达Xmx指定上限1.7g,Test1、Test2请求速度急剧下降,开场出现大量错包,422秒以后的错包率超过4.3%,且仍在在增加中,之前的错包率约为0.8%,测试终止。Test2413秒2922条/秒120万42500200万200毫秒Test11.7G 2742秒1727条/秒128万服务端从第740秒左右开场,tomcat占用内存到达Xmx指定上限1.7g,Test1、Test2请求速度急剧下降,开场出现大量错包,测试终止,到达1.7G前,错包率只有0.008%,到达1.7g后,截止停顿测试时,错包率增长到1.2%,且仍在在增加中。 web服务器负载小于2。Test
50、2744秒1608条/秒119万52500200万500毫秒Test11.7G 11595秒742条/秒118万服务端从第1595秒左右开场,tomcat占用内存到达Xmx指定上限1.7g,Test1、Test2请求速度急剧下降,开场出现大量错包,到达1.7G前,错包率只有0.08%,到达1.7g后,截止停顿测试时,错包率增长到2.3%,测试终止。Test21575秒737条/秒116万62500300万1000毫秒Test11.7G 16362秒471条/秒300万在测试进度到80%左右时,tomcat1占用内存到达了Xmx指定上限1.7g,但Test1、Test2请求速度并未下降,直到60
51、0万次请求全部完成,两个客户端分别有9个丢包,丢包率只有0.003%,最长的响应时长为12.728秒。Test26351秒472条/秒300万Nginx+2个TOMCAT的WEB服务器NO客户端数线程数请求次数间隔时间测试服务器Tomcat占用内存服务器负载持续时间平均速度完成请求数最大响应时长平均响应时长测试结果12250150万0毫秒Test11G 2347秒4322条/秒150万93005毫秒0.21毫秒300万次请求全部完成,无一错包。Test11G322秒4658条/秒150万21244毫秒0.23毫秒22500200万25毫秒Test11.4G 2542秒3690条/秒200万45
52、016毫秒0.27毫秒400万次请求全部完成,无一错包。Test21.4G544秒3676条/秒200万45014毫秒0.27毫秒32500300万50毫秒Test1 1.7G 21140秒2445条/秒278万服务端从第1100秒左右开场,Tomcat1、Tomcat2占用内存到达Xmx指定上限1.7g,Test1、Test2请求速度缓慢下降,但并无错包,人为终止测试。 Test21.7G1141秒2424条/秒276万42500300万200毫秒Test11.7G 11860秒1490条/秒277万服务端从第1800秒左右开场,Tomcat1、Tomcat2占用内存到达Xmx指定上限1.7
53、g,Test1、Test2请求速度缓慢下降,但并无错包,人为终止测试。Test21.7G1863秒1482条/秒276万52500500万500毫秒Test11.7G 15475秒913条/秒500万93000毫秒1.09毫秒完成测试,但Tomcat1、Tomcat2占用内存到达Xmx指定上限1.7g,无错包。Test21.7G5565秒898条/秒500万92987毫秒1.11毫秒62500500万1000毫秒Test1968M 110149秒492条/秒500万9077毫秒2.02毫秒完成测试,无一错包。Test21G10149秒492条/秒500万9044毫秒2.02毫秒Nginx+2个
54、TOMCAT的WEB服务器+缓冲NO客户端数线程数请求次数间隔时间测试服务器Tomcat占用内存服务器负载持续时间平均速度(条/秒)完成请求数最大响应时长平均响应时长测试结果12250150万0毫秒Test10.2G 164秒23437150万9993毫秒0.04毫秒Test20.2G59秒25423150万3472毫秒0.04毫秒22500200万25毫秒Test10.4G 1196秒10202200万9616毫秒0.10毫秒开启Nginx缓存后,400万次请求全部完成,分别有241和216个错包。Test20.4G194秒10361200万9608毫秒0.10毫秒32500300万50毫秒
55、Test10.4G 1379秒7915300万9015毫秒0.13毫秒开启Nginx缓存后,600万次请求全部完成,无一错包。Test20.2G384秒7812300万10234毫秒0.13毫秒42500300万200毫秒Test10.4G 11220秒2459300万3018毫秒0.40毫秒开启Nginx缓存后,600万次请求全部完成,无一错包。Test20.2G1241秒2417300万3384毫秒0.41毫秒52500500万500毫秒Test10.4G 15031秒993500万3020毫秒1.00毫秒开启Nginx缓存后,1000万次请求全部完成,无一错包。Test20.2G5055
56、秒989500万3394毫秒1.01毫秒62500500万1000毫秒Test10.4G1M、平均200K/页面,我们以平均值来计算。并发能力占用的网络带宽100次/秒228 M200次/秒457 M500次/秒1442 M1000次/秒2286 M架构和硬件配置选型硬件配置参考序号产品功能参考型号、配置TPMC1主机设备1.1数据库服务器IBM System x3850 M2, 4个处理器,每处理器为6核,共计24核。内存大小16G。SAS硬盘,硬盘大小587 GB。4U 机架,集成双千兆以太网接口,两块千兆的光纤网卡。6845081.2WEB服务器IBM System x3850 M2,
57、4个处理器,每处理器为6核,共计24核。内存大于8G。SAS硬盘,硬盘大小587 GB。4U 机架,集成双千兆以太网接口,两块千兆的光纤网卡。6845081.3管理终端IBM System x3560,1个Intel Xeon E5450处理器,内存大小2G,2U机架。326002网络设备2.1负载均衡器RADWARE应用负载均衡设备,型号:为ODS-504,有,4个可选的千兆位电端口,1G主内存,500M处理能力(最大可通过License升级为4G)2.2防火墙CISCO ASA5520防火墙并发连接:280000网络吞吐:450安全过滤:225MB网络端口:4个千兆以太网接口+1个快速用户
58、数限:无用户数限制用户VPN支持:支持2.2交换机Quidway S3952P-EI传输速率:10Mbps/100Mbps/1000Mbps网络标准:IEEE 802.1Q、IEEE 802.1D端口数量:48接口介质:10/100Base-T、1000Base-X传输模式:全双工/半双工自适应背板带宽:32Gbps3存储设备3.1光纤存储柜光纤存储柜EVA41003.2光纤交换机光纤交换机 4/32B SAN Switch注:上表为硬件的参考配置,根据网站规模的不同,在初期可以不用硬件负载均衡器。服务器性能也可以作适当缩减,到达一定规模后硬件的扩容请参考“4.3 HYPERLINK l _硬件扩容策略
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年度年福建省高校教师资格证之高等教育法规综合练习试卷B卷附答案
- 2024年xx村集体资金使用用途四议两公开专题会议记录
- 第二节 先天性行为和学习行为课件
- 四年级数学(上)计算题专项练习及答案
- 2024年专业泥工承揽协议模板
- 2024人力资源管理优化项目协议
- 2024砂石料订货与分销协议细则
- 2024年度企业债券投资与合作协议
- 计算机网络期末考试试题及答案完整版
- 高考英语分类汇编之阅读理解中最难语篇
- 零售督导工作流程
- 道闸系统施工方案
- 常微分方程与动力系统
- 2023年电子油门踏板行业洞察报告及未来五至十年预测分析报告
- 国有企业资金管理制度培训规范
- 2024年智能物流技术行业培训资料全面解析
- 精神障碍患者的社交技巧训练
- 青岛版科学(2017)六三制六年级上册实验报告单
- 如何在酒店管理中培养创新思维
- 合伙人协议 合伙经营协议全套
- 小学教学信息化管理章程
评论
0/150
提交评论