三大WEB服务器对比分析(apache ,lighttpd,nginx)
<strong>一.软件介绍</strong><strong>(apache lighttpd nginx)</strong>
<strong>1. lighttpd</strong>
Lighttpd是一个具有非常低的内存开销,cpu占用率低,效能好,以及丰富的模块等特点。lighttpd是众多OpenSource轻量级的web server中较为优秀的一个。支持FastCGI, CGI, Auth, 输出压缩(output compress), URL重写, Alias等重要功能。
Lighttpd使用fastcgi方式运行php,它会使用很少的PHP进程响应很大的并发量。
Fastcgi的优点在于:
· 从稳定性上看, fastcgi是以独立的进程池运行来cgi,单独一个进程死掉,系统可以很轻易的丢弃,然后重新分配新的进程来运行逻辑.
· 从安全性上看, fastcgi和宿主的server完全独立, fastcgi怎么down也不会把server搞垮,
· 从性能上看, fastcgi把动态逻辑的处理从server中分离出来, 大负荷的IO处理还是留给宿主server, 这样宿主server可以一心一意作IO,对于一个普通的动态网页来说, 逻辑处理可能只有一小部分, 大量的图片等静态IO处理完全不需要逻辑程序的参与(注1)
· 从扩展性上讲, fastcgi是一个中立的技术标准, 完全可以支持任何语言写的处理程序(php,java,python…)
<strong>2.</strong><strong>apache</strong>
apache是世界排名第一的web服务器, 根据netcraft(<a href="http://www.netsraft.co.uk/">www.netsraft.co.uk</a>)所作的调查,世界上百分之五十以上的web服务器在使用apache.
1995年4月, 最早的apache(0.6.2版)由apache group公布发行. apache group 是一个完全通过internet进行运作的非盈利机构, 由它来决定apache web服务器的标准发行版中应该包含哪些内容. 准许任何人修改隐错, 提供新的特征和将它移植到新的平台上, 以及其它的工作. 当新的代码被提交给apache group时, 该团体审核它的具体内容, 进行测试, 如果认为满意, 该代码就会被集成到apache的主要发行版中.
apache 的特性:
1) 几乎可以运行在所有的计算机平台上.
2) 支持最新的http/1.1协议
3) 简单而且强有力的基于文件的配置(httpd.conf).
4) 支持通用网关接口(cgi)
5) 支持虚拟主机.
6) 支持http认证.
7) 集成perl.
8) 集成的代理服务器
9) 可以通过web浏览器监视服务器的状态, 可以自定义日志.
10) 支持服务器端包含命令(ssi).
11) 支持安全socket层(ssl).
12) 具有用户会话过程的跟踪能力.
13) 支持fastcgi
14) 支持java servlets
<strong>3.</strong><strong>nginx</strong>
Nginx是俄罗斯人编写的十分轻量级的HTTP服务器,Nginx,它的发音为“engine X”, 是一个高性能的HTTP和反向代理服务器,同时也是一个IMAP/POP3/SMTP 代理服务器.Nginx是由俄罗斯人 Igor Sysoev为俄罗斯访问量第二的 Rambler.ru站点开发.
Nginx以事件驱动的方式编写,所以有非常好的性能,同时也是一个非常高效的反向代理、负载平衡。其拥有匹配 Lighttpd的性能,同时还没有Lighttpd的内存泄漏问题,而且Lighttpd的mod_proxy也有一些问题并且很久没有更新。但是Nginx并不支持cgi方式运行,原因是可以减少因此带来的一些程序上的漏洞。所以必须使用FastCGI方式来执行PHP程序。
nginx做为HTTP服务器,有以下几项基本特性:
处理静态文件,索引文件以及自动索引;打开文件描述符缓冲.
无缓存的反向代理加速,简单的负载均衡和容错.
FastCGI,简单的负载均衡和容错.
模块化的结构。包括gzipping, byte ranges, chunked responses,以及 SSI-filter等filter。如果由FastCGI或其它代理服务器处理单页中存在的多个SSI,则这项处理可以并行运行,而不需要相互等待。
Nginx专为性能优化而开发,性能是其最重要的考量,实现上非常注重效率。它支持内核Poll模型,能经受高负载的考验,有报告表明能支持高达 50,000个并发连接数。
Nginx具有很高的稳定性。其它HTTP服务器,当遇到访问的峰值,或者有人恶意发起慢速连接时,也很可能会导致服务器物理内存耗尽频繁交换,失去响应,只能重启服务器。例如当前apache一旦上到200个以上进程,web响应速度就明显非常缓慢了。而Nginx采取了分阶段资源分配技术,使得它的CPU与内存占用率非常低。nginx官方表示保持10,000个没有活动的连接,它只占2.5M内存,所以类似DOS这样的攻击对nginx来说基本上是毫无用处的。就稳定性而言,nginx比lighthttpd更胜一筹。
Nginx支持热部署。它的启动特别容易, 并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。你还能够在不间断服务的情况下,对软件版本进行进行升级。
<strong>二</strong><strong>.3</strong><strong>种</strong><strong>WEB</strong><strong>服务器的比较:</strong>
<div align="center">
<table border="1" width="100%" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td valign="top" width="27%"><strong>server</strong></td>
<td valign="top" width="19%"><strong>Apache</strong></td>
<td valign="top" width="24%"><strong>Nginx </strong></td>
<td valign="top" width="28%"><strong>Lighttpd</strong></td>
</tr>
<tr>
<td valign="top" width="27%">Proxy代理</td>
<td valign="top" width="19%">非常好</td>
<td valign="top" width="24%">非常好</td>
<td valign="top" width="28%">一般</td>
</tr>
<tr>
<td valign="top" width="27%">Rewriter</td>
<td valign="top" width="19%">好</td>
<td valign="top" width="24%">非常好</td>
<td valign="top" width="28%">一般</td>
</tr>
<tr>
<td valign="top" width="27%">Fcgi</td>
<td valign="top" width="19%">不好</td>
<td valign="top" width="24%">好</td>
<td valign="top" width="28%">非常好</td>
</tr>
<tr>
<td valign="top" width="27%">热部署</td>
<td valign="top" width="19%">不支持</td>
<td valign="top" width="24%">支持</td>
<td valign="top" width="28%">不支持</td>
</tr>
<tr>
<td valign="top" width="27%">系统压力比较</td>
<td valign="top" width="19%">很大</td>
<td valign="top" width="24%">很小</td>
<td valign="top" width="28%">比较小</td>
</tr>
<tr>
<td valign="top" width="27%">稳定性</td>
<td valign="top" width="19%">好</td>
<td valign="top" width="24%">非常好</td>
<td valign="top" width="28%">不好</td>
</tr>
<tr>
<td valign="top" width="27%">安全性</td>
<td valign="top" width="19%">好</td>
<td valign="top" width="24%">一般</td>
<td valign="top" width="28%">一般</td>
</tr>
<tr>
<td valign="top" width="27%">技术支持</td>
<td valign="top" width="19%">非常好</td>
<td valign="top" width="24%">很少</td>
<td valign="top" width="28%">一般</td>
</tr>
<tr>
<td valign="top" width="27%">静态文件处理</td>
<td valign="top" width="19%">一般</td>
<td valign="top" width="24%">非常好</td>
<td valign="top" width="28%">好</td>
</tr>
<tr>
<td valign="top" width="27%">Vhosts虚拟主机</td>
<td valign="top" width="19%">支持</td>
<td valign="top" width="24%">不支持</td>
<td valign="top" width="28%">支持</td>
</tr>
<tr>
<td valign="top" width="27%">反向代理</td>
<td valign="top" width="19%">一般</td>
<td valign="top" width="24%">非常好</td>
<td valign="top" width="28%">一般</td>
</tr>
<tr>
<td valign="top" width="27%">Session sticky</td>
<td valign="top" width="19%">支持</td>
<td valign="top" width="24%">不支持</td>
<td valign="top" width="28%">不支持</td>
</tr>
</tbody>
</table>
</div>
注:在相对<a href="http://action.vogate.com/c/c.php?r=http%3A//www.baidu.com/s%3Fct%3D0%26ie%3Dgb2312%26bs%3Dapache+lighttpd+nginx%25D3%25A6%25D3%25C3%26sr%3D%26z%3D%26cl%3D3%26f%3D8%26wd%3Dapache+lighttpd+nginx%25D7%25E9%25BA%25CF%25D3%25A6%25D3%25C3&aid=10416&sid=6235007045041793&click=1&url=http%3A//unionafa.allyes.com/main/adfclick%3Fdb%3Dunionafa%26bid%3D493%2C141%2C23%26cid%3D6601%2C309%2C1%26sid%3D362%26show%3Dignore%26url%3Dhttp%3A//buycar.chezhu.com.cn/promotion_0318.php%3Fcid%3D15&v=0&s=http%3A//www.diybl.com/course/1_web/webjs/200877/131436.html&rn=166740&k=%u6BD4%u8F83">比较</a>大的网站,节约下来的服务器成本无疑是客观的。而有些小型网站往往服务器不多,如果采用 Apache 这类传统 Web 服务器,似乎也还能撑过去。但有其很明显的弊端: Apache 在处理流量爆发的时候(比如爬虫或者是 Digg 效应) 很容易过载,这样的情况下采用 Nginx 最为合适。
建议方案:
Apache 后台服务器(主要处理php及一些功能请求 如:中文url)
Nginx 前端服务器(利用它占用系统资源少得优势来处理静态页面大量请求)
Lighttpd 图片服务器
总体来说,随着nginx功能得完善将使他成为今后web server得主流。
<strong>三</strong><strong>.</strong><strong>性能测试</strong>:
将分别测试3种软件在对动态页面和静态页面请求及并发时的响应时间
l <strong>静态页面 搜狐首页</strong>
LIGHTTPD
<div align="center">
<table border="1" width="100%" cellspacing="1" cellpadding="0">
<tbody>
<tr>
<td width="25%">n/-c(ab参数)</td>
<td width="13%">cpu%</td>
<td width="11%">Mem</td>
<td width="34%">RequestsperSecond</td>
<td valign="top" width="13%">Time taken for tests</td>
</tr>
<tr>
<td width="25%">100000/100</td>
<td width="13%">64</td>
<td width="11%">60</td>
<td width="34%">462.75</td>
<td valign="top" width="13%">21.6</td>
</tr>
<tr>
<td width="25%">100000/200</td>
<td width="13%">67</td>
<td width="11%">60</td>
<td width="34%">312.07</td>
<td valign="top" width="13%">32.4</td>
</tr>
<tr>
<td width="25%">100000/500</td>
<td width="13%">83</td>
<td width="11%">60</td>
<td width="34%">137.24</td>
<td valign="top" width="13%">72.8</td>
</tr>
<tr>
<td width="25%">100000/1000出现错误丢包</td>
<td width="13%">94</td>
<td width="11%">60</td>
<td width="34%">126.6</td>
<td valign="top" width="13%">78.9</td>
</tr>
</tbody>
</table>
</div>
NGINX
<div align="center">
<table border="1" width="100%" cellspacing="1" cellpadding="0">
<tbody>
<tr>
<td width="24%">n/-c(ab参数)</td>
<td width="13%">cpu%</td>
<td width="11%">Mem</td>
<td width="33%">RequestsperSecond</td>
<td valign="top" width="16%">Time taken for tests</td>
</tr>
<tr>
<td width="24%">100000/100</td>
<td width="13%">34.6</td>
<td width="11%">140</td>
<td width="33%">943.66</td>
<td valign="top" width="16%">10.597</td>
</tr>
<tr>
<td width="24%">100000/200</td>
<td width="13%">35.6</td>
<td width="11%">110</td>
<td width="33%">924.32</td>
<td valign="top" width="16%">10.818</td>
</tr>
<tr>
<td width="24%">100000/500</td>
<td width="13%">34.3</td>
<td width="11%">110</td>
<td width="33%">912.68</td>
<td valign="top" width="16%">10.956</td>
</tr>
<tr>
<td width="24%">100000/1000</td>
<td width="13%">37</td>
<td width="11%">160</td>
<td width="33%">832.59</td>
<td valign="top" width="16%">12.106</td>
</tr>
</tbody>
</table>
</div>
APACHE
<div align="center">
<table border="1" width="100%" cellspacing="1" cellpadding="0">
<tbody>
<tr>
<td width="24%">n/-c(ab参数)</td>
<td width="13%">cpu%</td>
<td width="11%">Mem</td>
<td width="34%">RequestsperSecond</td>
<td valign="top" width="14%">Time taken for tests</td>
</tr>
<tr>
<td width="24%">100000/100</td>
<td width="13%">40.6</td>
<td width="11%">170</td>
<td width="34%">690.72</td>
<td valign="top" width="14%">14.47</td>
</tr>
<tr>
<td width="24%">100000/200</td>
<td width="13%">41.1</td>
<td width="11%">180</td>
<td width="34%">685.39</td>
<td valign="top" width="14%">14.59</td>
</tr>
<tr>
<td width="24%">100000/500</td>
<td width="13%">42.3</td>
<td width="11%">190</td>
<td width="34%">633.64</td>
<td valign="top" width="14%">15.78</td>
</tr>
<tr>
<td width="24%">100000/1000</td>
<td width="13%">43.1</td>
<td width="11%">200</td>
<td width="34%">547.53</td>
<td valign="top" width="14%">18.26</td>
</tr>
</tbody>
</table>
</div>
l <strong>动态页面 内部社区首页</strong>
LIGHTTPD
<div align="center">
<table border="1" width="100%" cellspacing="1" cellpadding="0">
<tbody>
<tr>
<td width="21%">n/-c(ab参数)</td>
<td width="13%">cpu%</td>
<td width="11%">Mem</td>
<td width="34%">RequestsperSecond</td>
<td valign="top" width="16%">Time taken for tests</td>
</tr>
<tr>
<td width="21%">1000/100</td>
<td width="13%">50</td>
<td width="11%">200</td>
<td width="34%">33.54</td>
<td valign="top" width="16%">29.816</td>
</tr>
<tr>
<td width="21%">1000/200</td>
<td width="13%">52</td>
<td width="11%">210</td>
<td width="34%">30.43</td>
<td valign="top" width="16%">32.858</td>
</tr>
<tr>
<td width="21%">1000/500</td>
<td width="13%">54</td>
<td width="11%">230</td>
<td width="34%">25.79</td>
<td valign="top" width="16%">38.76</td>
</tr>
<tr>
<td width="21%">1000/1000</td>
<td width="13%">62</td>
<td width="11%">250</td>
<td width="34%">24.83</td>
<td valign="top" width="16%">40.28</td>
</tr>
</tbody>
</table>
</div>
NGINX
<div align="center">
<table border="1" width="100%" cellspacing="1" cellpadding="0">
<tbody>
<tr>
<td width="21%">n/-c(ab参数)</td>
<td width="13%">cpu%</td>
<td width="11%">Mem</td>
<td width="34%">RequestsperSecond</td>
<td valign="top" width="16%">Time taken for tests</td>
</tr>
<tr>
<td width="21%">1000/100</td>
<td width="13%">53.8</td>
<td width="11%">250</td>
<td width="34%">83.12</td>
<td valign="top" width="16%">12.305</td>
</tr>
<tr>
<td width="21%">1000/200</td>
<td width="13%">55.8</td>
<td width="11%">250</td>
<td width="34%">74.05</td>
<td valign="top" width="16%">13.504</td>
</tr>
<tr>
<td width="21%">1000/500</td>
<td width="13%">56</td>
<td width="11%">260</td>
<td width="34%">58.99</td>
<td valign="top" width="16%">16.951</td>
</tr>
<tr>
<td width="21%">1000/1000</td>
<td width="13%">58</td>
<td width="11%">260</td>
<td width="34%">43.41</td>
<td valign="top" width="16%">23.347</td>
</tr>
</tbody>
</table>
</div>
APACHE
<div align="center">
<table border="1" width="100%" cellspacing="1" cellpadding="0">
<tbody>
<tr>
<td width="24%">n/-c(ab参数)</td>
<td width="13%">cpu%</td>
<td width="11%">Mem</td>
<td width="33%">RequestsperSecond</td>
<td valign="top" width="16%">Time taken for tests</td>
</tr>
<tr>
<td width="24%">100000/100</td>
<td width="13%">60</td>
<td width="11%">200</td>
<td width="33%">27.37</td>
<td valign="top" width="16%">36.541</td>
</tr>
<tr>
<td width="24%">100000/200</td>
<td width="13%">61</td>
<td width="11%">220</td>
<td width="33%">23.82</td>
<td valign="top" width="16%">41.981</td>
</tr>
<tr>
<td width="24%">100000/500</td>
<td width="13%">73</td>
<td width="11%">150</td>
<td width="33%">20.59</td>
<td valign="top" width="16%">48.562</td>
</tr>
<tr>
<td width="24%">100000/1000</td>
<td width="13%">53</td>
<td width="11%">200</td>
<td width="33%">27.18</td>
<td valign="top" width="16%">36.796</td>
</tr>
</tbody>
</table>
</div>
l <strong>PHPINFO</strong><strong>函数页</strong>
LIGHTTPD
<div align="center">
<table border="1" width="100%" cellspacing="1" cellpadding="0">
<tbody>
<tr>
<td width="23%">n/-c(ab参数)</td>
<td width="12%">cpu%</td>
<td width="11%">Mem</td>
<td width="33%">RequestsperSecond</td>
<td valign="top" width="17%">Time taken for tests</td>
</tr>
<tr>
<td width="23%">100000/100</td>
<td width="12%">45</td>
<td width="11%">20</td>
<td width="33%">168.06</td>
<td valign="top" width="17%">59.504</td>
</tr>
<tr>
<td width="23%">100000/200</td>
<td width="12%">47</td>
<td width="11%">22</td>
<td width="33%">140.64</td>
<td valign="top" width="17%">71.103</td>
</tr>
<tr>
<td width="23%">100000/500</td>
<td width="12%">49</td>
<td width="11%">24</td>
<td width="33%">52.80</td>
<td valign="top" width="17%">189.386</td>
</tr>
<tr>
<td width="23%">100000/1000</td>
<td colspan="4" width="75%">在请求到4840时测试测试程序死掉</td>
</tr>
</tbody>
</table>
</div>
NGINX
<div align="center">
<table border="1" width="100%" cellspacing="1" cellpadding="0">
<tbody>
<tr>
<td width="24%">n/-c(ab参数)</td>
<td width="13%">cpu%</td>
<td width="11%">Mem</td>
<td width="33%">RequestsperSecond</td>
<td valign="top" width="16%">Time taken for tests</td>
</tr>
<tr>
<td width="24%">100000/100</td>
<td width="13%">70</td>
<td width="11%">120</td>
<td width="33%">143.46</td>
<td valign="top" width="16%">69.706</td>
</tr>
<tr>
<td width="24%">100000/200</td>
<td width="13%">72</td>
<td width="11%">130</td>
<td width="33%">140.57</td>
<td valign="top" width="16%">71.140</td>
</tr>
<tr>
<td width="24%">100000/500</td>
<td width="13%">73</td>
<td width="11%">150</td>
<td width="33%">135.87</td>
<td valign="top" width="16%">73.601</td>
</tr>
<tr>
<td width="24%">100000/1000</td>
<td width="13%">77</td>
<td width="11%">160</td>
<td width="33%">132.18</td>
<td valign="top" width="16%">75.657</td>
</tr>
</tbody>
</table>
</div>
APACHE 出现丢包
<div align="center">
<table border="1" width="100%" cellspacing="1" cellpadding="0">
<tbody>
<tr>
<td width="24%">n/-c(ab参数)</td>
<td width="13%">cpu%</td>
<td width="11%">Mem</td>
<td width="33%">RequestsperSecond</td>
<td valign="top" width="16%">Time taken for tests</td>
</tr>
<tr>
<td width="24%">100000/100</td>
<td width="13%">70</td>
<td width="11%">180</td>
<td width="33%">245.73</td>
<td valign="top" width="16%">40.694</td>
</tr>
<tr>
<td width="24%">100000/200</td>
<td width="13%">72</td>
<td width="11%">190</td>
<td width="33%">245.79</td>
<td valign="top" width="16%">40.684</td>
</tr>
<tr>
<td width="24%">100000/500</td>
<td width="13%">75</td>
<td width="11%">200</td>
<td width="33%">241.29</td>
<td valign="top" width="16%">41.443</td>
</tr>
<tr>
<td width="24%">100000/1000</td>
<td width="13%">77</td>
<td width="11%">220</td>
<td width="33%">236.74</td>
<td valign="top" width="16%">42.239</td>
</tr>
</tbody>
</table>
</div>
<strong>四.各大网站</strong><strong>WEB</strong><strong>服务器资源列表</strong>
网站名 操作系统 web服务器
<strong>1.</strong><strong>门户网站类:</strong>
搜狐 LINUX apache 1.3.37
新浪 LINUX apache 2.0.54
迅雷 LINUX nginx 0.6.31
163 LINUX apache 2.2.6
<strong>2.</strong><strong>搜索类</strong>
百度 unknown BWS 1.0
Google linux gws
Sougou FreeBSD apache 2.2.4
Hao123 linux apache 2.2.4
<strong>4. </strong><strong>电子邮箱类</strong>
126 linux apache
Hotmail win2003 microsoft-IIS 6.0
新浪邮箱 F5 Big-IP apache 2.2.8
263 linux apache 2.2.6
<strong>5. </strong><strong>博客类</strong>
新浪博客 linux nginx 0.5.35
搜狐博客 linux nginx
迅雷博客 linux nginx 0.6.32
天涯博客 F5 Big-IP Microsoft-IIS/5.0
<strong>6</strong><strong>.视频类</strong>
优酷 linux apache
土豆 linux apache
Ku6 linux apache
六间房 linux nginx 0.6.14