Nginx
Nginx是一个优秀的WEB服务器,Nginx有两大特性是Tomcat比不上的。
简介:
Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。
-
性能上比tomcat要强,nginx的并发比tomcat要高。
-
nginx支持反向代理。
正向代理,反向代理
代理
**正向代理:**某人像访问一个国外的网站,但是在国内无法访问,此时通过一个代理服务器告诉代理服务器要访问的的地址,访问了改网站
在正向代理之中,用户知道自己使用的代理服务器,并且知道目标服务的地址,代理工作是用户来操作的。
**反向代理:**用户访问了一个网站 www.baidu.com (110.242.68.4) 110.242.68.4服务器接收到这个请求后使用代理将请求发给了 110.242.68.4,然后由110.242.68.4 ,给用户提供服务
在反向代理中,用户并不知道自己访问的目标是否被代理过,所有的代理都是由服务器端完成的,也就是指用户实际上并不知道那天服务器处理的自己的请求
Nginx通过反向代理可以实现服务器的负载均衡,所谓负载均衡是将请求按照一定的规策略分发给所有的服务器。
根据nginx的特性,可以实现很多功能,例如做后端的负载均衡服务器,由HTTP性能较好所以可以作为前端的静态资源服务器,或者在商城秒杀高并发的情况做限流等操作。
- 使用nginx配合tomcat集群搭建高可用的负载均衡的后台服务
nginx安装目录详解
[root@Test2 nginx]# ls
conf html logs sbin
conf 存放nginx的配置文件
html 存放nginx自身的静态页面
logs 存放日志
sbin存放命令
Nginx中最终要的配置文件就是nginx.conf
nginx 负载均衡的策略
轮询(默认) - 按照顺序一次一次的来提供服务
-
轮询(默认) 就是安装顺序一次一次的来提供服务,在使用轮询的时候我们可以通过weight属性来配置权重,主要用于服务器性能不等的情况,权重越高处理请求的次数越高
# 指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。 # 例如: #upstream xx{ # server 192.168.153.129:8080 weight=10; # server 192.168.153.129:8081 weight=10; #}
-
ip_hash nginx根据用户的ip地址地址求出hash值然后分给对应的服务器处理用户请求
#每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。 #例如: #upstream bakend { # ip_hash; # server 192.168.153.129:8080; # server 192.168.153.129:8081; #}
-
url_hash 根据用户访问到url地址来分配请求,多个用户访问同一个地址是同一个服务器处理,一个用户访问不同的url会有不同的服务器处理,nginx不支持url_hash,如果需要使用url_hash需要下载nginx的hash软件包
# 按后端服务器的响应时间来分配请求,响应时间短的优先分配。 #upstream xx { # server 192.168.153.129:8080; # server 192.168.153.129:8081; # fair; #}
-
fair 更加智能的负载均衡算法,可以根据响应页面的大小以及加载时间长短来进行智能的负载均衡。后台服务器谁响应的快谁就负责更多的请求,nginx不支持fair,如果需要使用fair需要下载nginx的upstream-fair模块
#按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。 #例:在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法 #upstream xx { # server 192.168.153.129:8080; # server 192.168.153.129:8081; # hash $request_uri; # hash_method crc32; #}
Nginx相关面试题
1、请解释一下什么是Nginx?
Nginx是一个web服务器和方向代理服务器,用于HTTP、HTTPS、SMTP、POP3和IMAP协议。
2、请列举Nginx的一些特性。
Nginx服务器的特性包括:
反向代理/负载均衡器
嵌入式Perl解释器
动态二进制升级
可用于重新编写URL,具有非常好的PCRE支持
3、请列举Nginx和Apache 之间的不同点。
1:nginx相对于apache的优点: 轻量级,同样起web 服务,比apache 占用更少的内存及资源 ,抗并发,nginx 处理请求是异步非阻塞的,而apache 则是阻塞型的
2:作为 Web 服务器:相比 Apache,Nginx 使用更少的资源,支持更多的并发连接,体现更高的效率
3:Nginx 配置简洁, Apache 复杂 ,Nginx 静态处理性能比 Apache 高 3倍以上 ,Apache 对 PHP 支持比较简单,Nginx 需要配合其他后端用 ,Apache 的组件比 Nginx 多
4:nginx处理动态请求是鸡肋,一般动态请求要apache去做,nginx只适合静态服务器和反向代理
4、请解释Nginx如何处理HTTP请求。
Nginx使用反应器模式。主事件循环等待操作系统发出准备事件的信号,这样数据就可以从套接字读取,在该实例中读取到缓冲区并进行处理。单个线程可以提供数万个并发连接。
5、在Nginx中,如何使用未定义的服务器名称来阻止处理请求?
只需将请求删除的服务器就可以定义为:
Server {
listen 80;
server_name “ “ ;
return 444;
}
这里,服务器名被保留为一个空字符串,它将在没有“主机”头字段的情况下匹配请求,而一个特殊的Nginx的非标准代码444被返回,从而终止连接。
6、 使用“反向代理服务器”的优点是什么?
反向代理服务器可以隐藏源服务器的存在和特征。它充当互联网云和web服务器之间的中间层。这对于安全方面来说是很好的,特别是当您使用web托管服务时。
7、请列举Nginx服务器的最佳用途。
Nginx服务器的最佳用法是在网络上部署动态HTTP内容,使用SCGI、WSGI应用程序服务器、用于脚本的FastCGI处理程序。它还可以作为负载均衡器以及静态代理服务器。
8、请解释Nginx服务器上的Master和Worker进程分别是什么?
Master进程:读取及评估配置和维持
Worker进程:处理请求
9、请解释你如何通过不同于80的端口开启Nginx?
为了通过一个不同的端口开启Nginx,你必须进入/etc/Nginx/sites-enabled/,如果这是默认文件,那么你必须打开名为“default”的文件。编辑文件,并放置在你想要的端口:
Like server { listen 81; }
10、请解释是否有可能将Nginx的错误替换为502错误503?
502 =错误网关
503 =服务器超载
有可能,但是您可以确保fastcgi_intercept_errors被设置为ON,并使用错误页面指令。
Location / {fastcgi_pass 127.0.01:9001;fastcgi_intercept_errors on;error_page 502 =503/error_page.html;#…
}
11、在Nginx中,解释如何在URL中保留双斜线?
要在URL中保留双斜线,就必须使用merge_slashes_off;
语法:merge_slashes [on/off]
默认值: merge_slashes on
环境: http,server
12、请解释ngx_http_upstream_module的作用是什么?
ngx_http_upstream_module用于定义可通过fastcgi传递、proxy传递、uwsgi传递、memcached传递和scgi传递指令来引用的服务器组。
13、请解释什么是C10K问题?
C10K问题是指无法同时处理大量客户端(10,000)的网络套接字。
14、请陈述stub_status和sub_filter指令的作用是什么?
Stub_status指令:该指令用于了解Nginx当前状态的当前状态,如当前的活动连接,接受和处理当前读/写/等待连接的总数
Sub_filter指令:它用于搜索和替换响应中的内容,并快速修复陈旧的数据
*15、解释Nginx是否支持将请求压缩到上游?
您可以使用Nginx模块gunzip将请求压缩到上游。gunzip模块是一个过滤器,它可以对不支持“gzip”编码方法的客户机或服务器使用“内容编码:gzip”来解压缩响应。
16、解释如何在Nginx中获得当前的时间?
要获得Nginx的当前时间,必须使用SSI模块、 d a t e g m t 和 date_gmt和 dategmt和date_local的变量。
Proxy_set_header THE-TIME $date_gmt;
17、用Nginx服务器解释-s的目的是什么?
用于运行Nginx -s参数的可执行文件。
18、解释如何在Nginx服务器上添加模块?
在编译过程中,必须选择Nginx模块,因为Nginx不支持模块的运行时间选择。
19、Nginx是如何实现高并发的
答:一个主进程,多个工作进程,每个工作进程可以处理多个请求,每进来一个request,会有一个worker进程去处理。但不是全程的处理,处理到可能发生阻塞的地方,比如向上游(后端)服务器转发request,并没有等待请求返回。这个处理的worker继续处理其他请求,而一旦上游服务器返回了,就会触发这个事件,worker才会来接手,这个request才会接着往下走。由于web server的工作性质决定了每个request的大部份生命都是在网络传输中,实际上花费在server机器上的时间片不多。这是几个进程就解决高并发的秘密所在。