LAMP(LinuxApacheMySQLPHP)网站架构是目前国际流行的Web框架该框架包括Linux操作系统Apache网络服务器MySQL数据库PerlPHP或者Python编程语言所有组成产品均是开源软件是国际上成熟的架构框架很多流行的商业应用都是采取这个架构和Java/JEE架构相比LAMP具有Web资源丰富轻量快速开发等特点微软的NET架构相比LAMP具有通用跨平台高性能低价格的优势因此LAMP无论是性能质量还是价格都是企业搭建网站的首选平台
对于大流量大并发量的网站系统架构来说除了硬件上使用高性能的服务器负载均衡CDN等之外在软件架构上需要重点关注下面几个环节使用高性能的操作系统(OS)高性能的网页服务器(Web Server)高性能的数据库(Databse)高效率的编程语言等下面我将从这几点对其一一讨论
操作系统
Linux操作系统有很多个不同的发行版如Red Hat Enterprise LinuxSUSE Linux EnterpriceDebianUbuntuCentOS等每一个发行版都有自己的特色比如RHEL的稳定Ubuntu的易用基于稳定性和性能的考虑操作系统选择CentOS(Community ENTerprise Operating System)是一个理想的方案
CentOS(Community ENTerprise Operating System)是Linux发行版之一是RHEL/Red Hat Enterprise Linux的精简免费版和RHEL为同样的源代码不过RHEL和SUSE LE等企业版提供的升级服务均是收费升级无法免费在线升级因此要求免费的高度稳定性的服务器可以用CentOS替代Red Hat Enterprise Linux使用
服务器Nginx以它的稳定性丰富的功能集示例配置文件和低系统资源的消耗而闻名Nginx不支持PHP和CGI等动态语言但支持负载均衡和容错可和Apache配合使用是轻量级的HTTP服务器的首选
Web服务器的缓存也有多种方案Apache提供了自己的缓存模块也可以使用外加的Squid模块进行缓存这两种方式均可以有效的提高Apache的访问响应能力Squid Cache是一个Web缓存服务器支持高效的缓存可以作为网页服务器的前置cache服务器缓存相关请求来提高Web服务器的速度把Squid放在Apache的前端来缓存Web服务器生成的动态内容而Web应用程序只需要适当地设置页面实效时间即可如访问量巨大则可考虑使用memcache作为分布式缓存
PHP的加速使用eAccelerator加速器eAccelerator是一个自由开放源码PHP加速器优化和动态内容缓存提高了性能PHP脚本的缓存性能使得PHP脚本在编译的状态下对服务器的开销几乎完全消除它还有对脚本起优化作用以加快其执行效率使PHP程序代码执效率能提高倍
具体的解决方案有以下几种
squid + Apache + PHP + eAccelerator
使用Apache负载PHP使用squid进行缓存html或图片的请求可以直接由squid返回给用户很多大型网站都采用这种架构
nginx/Apache + PHP(fastcgi) + eAccelerator
使用nginx或Apache负载PHPPHP使用fastcgi方式运行效率较高
nginx + Apache + PHP + eAccelerator
此方案综合了nginx和Apache的优点使用Apache负载PHPnginx负责解析其他Web请求使用nginx的rewrite模块Apache端口不对外开放
数据库
开源的数据库中MySQL在性能稳定性和功能上是首选可以达到百万级别的数据存储网站初期可以将MySQL和Web服务器放在一起但是当访问量达到一定规模后应该将MySQL数据库从Web Server上独立出来在单独的服务器上运行同时保持Web Server和MySQL服务器的稳定连接
当数据库访问量达到更大的级别可以考虑使用MySQL Cluster等数据库集群或者库表散列等解决方案
总的来说LAMP架构的网站性能会远远优于Windows IIS + ASP + Access(例如月光博客)这样的网站可以负载的访问量也非常大国内的大量个人网站如果想要支撑大访问量采用LAMP架构是一个不错的方案
综上所述基于LAMP架构设计具有成本低廉部署灵活快速开发安全稳定等特点是Web网络应用和环境的优秀组合