您好,欢迎访问三七文档
1lamp网站架构LAMP(Linux-Apache-MySQL-PHP)网站架构是目前国际流行的Web框架,该框架包括:Linux操作系统,Apache网络服务器,MySQL数据库,Perl、PHP或者Python编程语言,所有组成产品均是开源软件,是国际上成熟的架构框架,很多流行的商业应用都是采取这个架构,和Java/J2EE架构相比,LAMP具有Web资源丰富、轻量、快速开发等特点,微软的.NET架构相比,LAMP具有通用、跨平台、高性能、低价格的优势,因此LAMP无论是性能、质量还是价格都是企业搭建网站的首选平台。对于大流量、大并发量的网站系统架构来说,除了硬件上使用高性能的服务器、负载均衡、CDN等之外,在软件架构上需要重点关注下面几个环节:使用高性能的操作系统(OS)、高性能的网页服务器(WebServer)、高性能的数据库(Databse)、高效率的编程语言等。下面我将从这几点对其一一讨论。操作系统Linux操作系统有很多个不同的发行版,如RedHatEnterpriseLinux、SUSELinuxEnterprice、Debian、Ubuntu、CentOS等,每一个发行版都有自己的特色,比如RHEL的稳定,Ubuntu的易用,基于稳定性和性能的考虑,操作系统选择CentOS(CommunityENTerpriseOperatingSystem)是一个理想的方案。CentOS(CommunityENTerpriseOperatingSystem)是Linux发行版之一,是RHEL/RedHatEnterpriseLinux的精简免费版,和RHEL为同样的源代码,不过,RHEL和SUSELE等企业版,提供的升级服务均是收费升级,无法免费在线升级,因此要求免费的高度稳定性的服务器可以用CentOS替代RedHatEnterpriseLinux使用。LAMP网站架构图Web服务器、缓存和PHP加速Apache是LAMP架构最核心的WebServer,开源、稳定、模块丰富是Apache的优势。但Apache的缺点是有些臃肿,内存和CPU开销大,性能上有损耗,不如一些轻量级的Web服务器(例如nginx)高效,轻量级的Web服务器对于静态文件的响应能力来说远高于Apache服务器。Apache做为WebServer是负载PHP的最佳选择,如果流量很大的话,可以采用nginx来负载非PHP的Web请求。nginx是一个高性能的HTTP和反向代理服务器,Nginx以它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。Nginx不支持PHP和CGI等动态语言,但支持负载均衡和容错,可和Apache配合使用,是轻量级的HTTP服务器的首选。Web服务器的缓存也有多种方案,Apache提供了自己的缓存模块,也可以使用外加的Squid模块进行缓存,这两种方式均可以有效的提高Apache的访问响应能力。SquidCache是一个Web缓存服务器,支持高效的缓存,可以作为网页服务器的前置cache服务器缓存相关请求来提高Web服务器的速度,把Squid放在Apache的前端来缓存Web服务器生成的动态内容,而Web应用程序只需要适当地设置页面实效时间即可。如访问量巨大则可考虑使用memcache作为分布式缓存。PHP的加速使用eAccelerator加速器,eAccelerator是一个自由开放源码PHP加速器,优化和动态内容缓存,提高了性能PHP脚本的缓存性能,使得PHP脚本在编译的状态下,对服务器的开销几乎完全消除。它还有对脚本起优化作用,以加快其执行效率。使PHP程序代码执效率能提高1-10倍。具体的解决方案有以下几种:1、squid+Apache+PHP+eAccelerator使用Apache负载PHP,使用squid进行缓存,html或图片的请求可以直接由squid返回给用户。很多大型网站都采用这种架构。2、nginx/Apache+PHP(fastcgi)+eAccelerator使用nginx或Apache负载PHP,PHP使用fastcgi方式运行,效率较高。3、nginx+Apache+PHP+eAccelerator此方案综合了nginx和Apache的优点,使用Apache负载PHP,nginx负责解析其他Web请求,使用nginx的rewrite模块,Apache端口不对外开放。数据库开源的数据库中,MySQL在性能、稳定性和功能上是首选,可以达到百万级别的数据存储,网站初期可以将MySQL和Web服务器放在一起,但是当访问量达到一定规模后,应该将MySQL数据库从WebServer上独立出来,在单独的服务器上运行,同时保持WebServer和MySQL服务器的稳定连接。当数据库访问量达到更大的级别,可以考虑使用MySQLCluster等数据库集群或者库表散列等解决方案。总的来说,LAMP架构的网站性能会远远优于WindowsIIS+ASP+Access(例如月光博客)这样的网站,可以负载的访问量也非常大,国内的大量个人网站如果想要支撑大访问量,采用LAMP架构是一个不错的方案。综上所述,基于LAMP架构设计具有成本低廉、部署灵活、快速开发、安全稳定等特点,是Web网络应用和环境的优秀组合。2大规模网站架构8U网络推广是中国互联网应用服务优质提供商中国8U旗下推广团队。8U网络推广团队是一个集网络推广与网络营销一体的专业网络推广平台。服务对象包括:企业、产品、政府、个人、游戏、赛事、活动、影视节目、网络小说等。8U网络推广团队拥有专业的网络推广技术和网络推广方案,并拥有众多媒体资源以及良好的信誉,能够提供专业的网络推广服务。•PHP–facebook,yahoo•Java–taobao,163•Python–google•.NET–MySpace语言不是可伸缩性的关键,架构才是关键网站架构的目标•高可用性(HighAvailability)•可伸缩性(Scalability)•高性能(HighPerformance)事务传统的事务(ACID)•原子性(Atomicity)•一致性(Consistency)•隔离性(Isolation)•持久性(Durability)CAP原则•Consistency一致性•Availability可用性•PartitionTolerance分区耐受性•在任意时刻,只有两项能同时成立•不要浪费精力可能突破上面限制新的事务策略-BASE策略•避免分布式事务•基本可用(BasicallyAvailable)•软状态(Softstate)•选择最终一致(Eventuallyconsistent)数据库读写分离MySQLProxy(数据库读写分离)•loadbalancing•failover•queryanalysis•R/WSplitting数据库Shard•水平分区•垂直分区ShardingvsPartitionShardingPartition存储依赖可跨越DB可跨越物理机器可跨越表空间,不同的物理属性不能跨DB存储存储方式分布式集中式扩展性ScaleOut(横向扩展,增加便宜设备)ScaleUp(升级设备)可用性无单点存在单点(DB数据本身)价格低廉适中,甚至昂贵应用场景web2.0网站多数传统应用垂直分区水平分区userblogAppDAL水平分区DAL(数据访问层)•对应用透明的使用数据库的水平分区及垂直分区DALProxy(实现1)user33%user33%AppDALuser34%DALAPI(实现2)DALProxy(实现1)DALAPI(实现2)应用DAL服务器useruser应用DALuseruser应用DAL服务器useruser两种实现方式•独立的DALProxy服务器–MySQL:Amoeba–PostgreSQL:PL/Proxy(Skype)•DALAPI–Java:HibernateShard,IbatisShard,HiveDB–Python:Pyshardsshard改变数据库设计•尽量避免join•数据冗余/反范式数据冗余forshard•shardbefore–comment(id,blog_id,content)•shardafter–comment(id,blog_id,content,user_id)数据分区策略•水平分区–2*N(如定单,购买者与网店各一份)–N/n(按日期或ID范围分区)–hash(N)%n(按hash分)–查找表•垂直分区–按功能分(论坛,博客)消息队列(MessageQueue)•程序解耦•隔离•消息的可靠传输(物理存储中转消息)消息总线应用DALuseruser应用场景•耗时操作–邮件发送/短消息发送•日志•程序解耦(A挂了,但B继续可以使用)MQ产品•开源–RabbitMQ(Erlang)–ActiveMQ(JAVA)•商业–IBMMQ–WebLogicMQ回顾CAP及BASE负载均衡•DNS负载均衡•反向代理负载均衡•直接路由•......failoverDNS负载均衡反向代理负载均衡•负载均衡软件–nginx–HAProxy–apachehttpd–LVS(网络第四层工作)–F5(硬件,四层/七层)D:\python\Django-1.1.1nslookup:10.20.18.10Non-authoritativeanswer:Name::(LVS)网络地址转换(NAT):VS-NATIP隧道方式:VS-TUN直接路由方式:VS-DR其它工作模式•VirtualServerviaNAT(VS-NAT)–用地址翻译实现虚拟服务器。地址转换器有能被外界访问到的合法IP地址,它修改来自专有网络的流出包的地址。外界看起来包是来自地址转换器本身,当外界包送到转换器时,它能判断出应该将包送到内部网的哪个节点。优点是节省IP地址,能对内部进行伪装;缺点是效率低,因为返回给请求方的流量经过转换器。•VirtualServerviaIPTunneling(VS-TUN)–用IP隧道技术实现虚拟服务器。这种方式是在集群的节点不在同一个网段时可用的转发机制,是将IP包封装在其他网络流量中的方法。为了安全的考虑,应该使用隧道技术中的VPN,也可使用租用专线。集群所能提供的服务是基于TCP/IP的Web服务、Mail服务、News服务、DNS服务、Proxy服务器等等.•VirtualServerviaDirectRouting(VS-DR)–用直接路由技术实现虚拟服务器。当参与集群的计算机和作为控制管理的计算机在同一个网段时可以用此法,控制管理的计算机接收到请求包时直接送到参与集群的节点。优点是返回给客户的流量不经过控制主机,速度快开销少。高可用性•使用双机热备•故障时切换至备份机•工具(Linux-HA)–heartbeat缓存•让数据更靠近用户DataBaseMemchchedAppCachePageCache/StaticBrowseCacheThreePartyCDN本地缓存•节点有状态,状态更新需要同步至其它服务器–可以使用组播方式通知数据改变–需要通知的服务器过多会存在性能问题•比远程缓存更高性能•慎用,不具备可伸缩性ShareNothingArchitecture无共享架构•数据缓存(memchched)•动态内容缓存•浏览器缓存数据缓存•分布式memchched•基本满足大部分性能要求动态内容缓存•页面片段缓存•静态化内容反向代理缓存•squid巨无霸•Varnish反向代理缓存静态资源分离Varnish缓存tomcatNginx负载
本文标题:lamp网站架构
链接地址:https://www.777doc.com/doc-6338598 .html