有人说这些基准测试是不准确的,因为在这样那样的环境下,做的比较不一致。我倾向同意基准测试只是告诉了我们其中一部分情况,你能做的是消除偏见(有人见过所有人都同意一个基准测试是公平的吗?我是没见过。)
不管怎样,这篇文章不是做基准测试来让人们争论(如果你喜欢,可以在Google上找到那样的文章),相反,下面的引述来自人们在现实世界中使用Nginx,在真实的负载下,服务于真正的应用和网站。
引述
我们投资的一些公司把web平台切换到Nginx后,可以显著的解决扩展问题。Nginx明显有效的实现了今天互联网上最大网站数量的增长。
– Thomas Gieselmann, BV Capital
我
对今天运行网站的所有人的建议是,想打破性能限制就研究下能否使用Nginx。CloudFlare去年在一个相对较小的基础设施上已经扩展到可以处理每
月超过150亿的浏览量,很大程度上是因为Nginx的扩展性。我的经验表明切换到Nginx可以最大限度的利用现代的 *** 作系统和现有的硬件资源。
– Matthew Prince, CloudFlare的联合创始人和CEO
Apache和Nginx都有能力提供每秒钟庞大的请求服务,但是随着并发数量的增加,Apache的性能开始下降,然而Nginx的性能几乎不会下降。
这里最好的一点是:因为Nginx是基于事件的,它不用为每个请求产生新的进程或线程,所以它的内存使用很低。在我的基准测试中,它的内存使用坐落在25M,Apache使用得更多。
– WebFaction
针
对Nginx v0522 and Apache
v228我用ab(Apache的基准测试工具)跑了一个简单的测试。在测试过程中,我用vmstat和top检测系统。结果表明在提供静态内容
时,Nginx做得比Apache好。两个服务器都在并发数100时表现最佳。Apache使用4个工作进程(线程模式),30%的CPU和17MB的内
存,每秒钟处理6,500次请求。Nginx使用一个工作进程,15%的CPU,1MB内存,每秒钟处理11,500次请求。
– Linux Journal
Apache好比是微软Word,它有100万个选项,但是你只需要其中6个。Nginx就处理那6项任务,但处理其中5项任务时速度比Apache快50倍。
– Chris Lea
我现在使用Nginx在单一服务器上处理每天超过数千万(也就是每秒钟几百次)的反向代理>Nginx是一款非常流行的Web服务器软件,它的设计重点是性能、高度可配置性和低资源消耗。Nginx可以用作反向代理服务器,也可以用作负载均衡器,以提高响应性能和可伸缩性。Nginx可以使用多种可配置变量来定制用户体验,这些变量包括:
1 Backend Server:指定要使用的后端服务器,可以设置单个服务器,或者是多个服务器。
2 Proxy Buffers:控制代理缓冲区的大小,以及缓冲区中存储的内容,可以提高服务器的性能。
3 Proxy Timeouts:设置超时时间,以便有效的对应用程序的请求 *** 作。
4 Proxy Cache:控制缓存的大小,可以有效的提高服务器的性能。
5 Proxy Redirect:重定向客户端的请求,以支持更多的应用程序功能。
6 SSL Protocols:可以控制服务器支持的SSL协议,以改善安全性。
7 >将 NGINX 配置为 >
Nginx确实是比较常用的技术(服务器)之一,不仅Java应用可以使用到,它可以应用在很多场景下。下面我就按照自己的理解,向大家介绍一下。
什么是Nginx
如果你是Java程序员,没用听说过Nginx的话,那么你肯定听说过Apache吧。Nginx也是一样,是一种WEB服务器。它有以下特点:
是使用C语言开发出来的,基于事件驱动架构,性能很高,高并发能力极强;
跨平台,可以运行在windows、Linux、Mac、Solaris等 *** 作系统上;
第三方模块很多(生态环境好)。
那么我们再看看Nginx能做什么:
反向代理
这个概念大家一定很耳熟,那么在说反向代理之前,先看看什么是正向代理。
正向代理:我想访问谷歌,没办法直接访问,这时候找一个代理服务器,我通过代理服务器访问谷歌;正向代理特点是客户端知道要访问的服务器地址是什么;服务器不知道客户端是谁,正向代理-代理的是客户端;
反向代理:代理服务器接收互联网端的请求,转发请求到内网中的服务器(可能会是多台服务器中的一台),得到服务器的响应之后,再把响应返回给客户端;这时候客户端不知道服务器在哪,反向代理-代理的是服务端。
在一个项目的架构中,正向代理和反向代理可能同时存在。
负载均衡
因为Nginx可以做反向代理服务器,它可以把客户端的请求发送给服务器端;客户端的请求数量,就是负载量。
那么把负载量,按照一定的规则,分发给不同的服务器就行处理,这个就叫做负载均衡;负载均衡的好处,就是把压力平均到每一台服务器上。负载均衡的调度方法有:轮询,一个一个轮着发;ip_hash;url_hash;fair等。
总之,Nginx是常用的软件(服务器)之一,最好学习一下。
我将持续分享Java开发、架构设计、程序员职业发展等方面的见解,希望能得到你的关注。
Nginx (engine x) 是一个高性能的>
Nginx是一款轻量级的Web 服务器和反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。
服务器是硬件(身体),NGINX是软件(灵魂):服务器需要NGINX APACHE 或者IIS 才能作为网站服务器。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)