码迷,mamicode.com
首页 > 其他好文 > 详细

Nginx

时间:2018-09-08 22:31:16      阅读:182      评论:0      收藏:0      [点我收藏+]

标签:获得   accept   分离   jpg   链接   时代   初始   三次握手   平台   

1、什么是Nginx 

Ngin是一个高性能的HTTP和反向代理服务器,及电子邮件(IMAP/POP3)代理服务器,同事也是一个非常高效的反向代理、负载均衡。

2、为什么要用Nginx

优点:

跨平台、配置简单

非阻塞、高并发连接:处理2-3万并发连接数,官方检测能支持5万并发

内存消耗小:开启10个Nginx才占150M内存,Nginx采用了分阶段资源分配技术

Nginx处理静态文件好,耗费内存少

内置的健康检查功能:如果有一个服务器宕机,会做一个健康检查,在发送的请求就不会发送到宕机的服务器了。重新将请求提交到其他的节点上。

节省宽带:支持GZIP压缩,可以添加浏览器本地缓存

稳定性高:宕机的概率非常小

master/worker结构:一个mastr进程,生成一个货者多个worker进程

接收用户请求是异步的:浏览器将请求发送到nginx服务器,它现将用户请求全部接收下来,再一次性发送到后端web服务器,极大减轻了web服务器的压力,一边接收web服务器的返回数据,一边发送给浏览器客户端,网络依赖性比较低,只要ping通就可以负载均衡,可以有多台nginx服务器

事件驱动:通信机制采用epoll模型

3、为什么nginx性能这么高

得益于它的事件机制:

异步非阻塞事件处理机制:运用了epoll模型,提供了一个队列,排列解决

4、为什么不使用多线程

Apache:创建多个进程,而每个进程或线程都会为其分配cpu和内存(线程要比进程小的多,所以worker支持比perfork高的并发),并发过大会榨干服务器资源。

Nginx:采用单线程来异步非阻塞处理请求(管理员可以配置Nginx主进程的工作进程的数量)(epoll),不会为每个请求分配cpu和内存资源,节省了大量资源,同时也减少了大量的cpu的上下文切换。所以才使得Nginx支持更高的并发。

5、Nginx是如何处理一个请求的

首先,Nginx在启动时,会解析配置文件,得到需要监听的端口与ip地址,然后在Nginx的master进程里面先初始化好这个监控的socket,在进行listen,然后在fork处多个子进程出来,子进程会竞争accept新的连接。此时,客户端就可以向Nginx发起连接了。当客户端与Nginx进行三次握手,与Nginx建立好一个链接后,此时,某一个子进程会accept成功,然后创建nginx对链接的封装,即 ngx_connection_t结构体,接着,根据事件调用相应的事件处理模块,如http模块与客户端进行数据交换。最后,Nginx或客户端来主动关掉连接,到此,一个连接就寿终就寝了。

6、正向代理

一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理

正向代理总结就是一句话:代理端代理的就是客户端

7、反向代理

反向代理(reveerse proxy)方式是指以代理服务器来接收internet上的连接请求,然后将请求发送给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器

反向代理服务器总结就是一句话:代理端代理的是服务端

8、动态资源、静态资源分离

动态资源、静态资源分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变得资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路

动态资源、静态资源分离简单的概括是:动态文件与静态文件的分离

9、为什么要做动静分离

在我们的软件开发中,有些请求是需要后台处理的(如:.jsp ,  .do 等等),有些请求是不需要经过后台处理的(如:css  ,  html  ,  jpg  ,   js等等文件),这些不需要经过后台处理的文件称为静态文件,否则动态文件,因此我们后台处理忽略静态文件。这会有人又说那我后台忽略静态文件那不就完了吗,当然这是可以的,但是这样后台的请求次数就明显增多了。在我们对资源的响应速度有要求的时候,我们应该使用这种动静分离的策略去解决,动静分离将网站静态资源(HTML,JavaScript,CSS,img等文件)与后台应用分开部署,提高用户访问静态代码的速度,降低对后台应用访问,在这里我们将静态资源放到Nginx中,动态资源转发到tomcat服务器中

10、负载均衡

负载均衡即是代理服务器将接受的请求均衡的分发到各服务器中,负载均衡主要解决网络拥塞问题,提高服务器的响应速度,服务就近提供,达到更好的访问质量,减少后台服务器大并发压力。

Nginx

标签:获得   accept   分离   jpg   链接   时代   初始   三次握手   平台   

原文地址:https://www.cnblogs.com/lz0504/p/9610310.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!