Nginx的基本概念和原理
目录
- 一、Nginx基本概念
- 二、反向代理
- 三、负载均衡
- 四、动静分离
- 五、原理
- 六、worker如何工作
一、Nginx基本概念 (engine x)是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。其特点是占有内存少,并发能力强,事实上
nginx
的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。Nginx专为性能优化而开发,性能是器最重要的考量,实现上非常注重效率,能经受高负载的考验,据报告能支持高达50,000个并发连接数。
Nginx不仅能做反向代理,实现负载均衡;还能可以作正向代理来进行上网等功能。
二、反向代理 在客户端(浏览器)配置代理服务器,通过代理服务器进行互联网访问。代理对象是客户端,不知道服务端是谁。
文章图片
客户端不需要任何配置就能访问,只需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器,获取数据后再返回给客户端。对外就一个服务器,暴露的是反向代理服务器地址,隐藏了真实服务器IP地址。代理对象是服务端,不知道客户端是谁。
文章图片
三、负载均衡 客户端发送多个请求到服务器,服务器处理请求,有些可能要访问数据库,服务器处理完毕后再将结果返回客户端。
这种架构模式单一,适合并发请求少的情况,但并发量大的时候如何解决?
文章图片
首先可能想到升级服务器配置,但硬件的性能提升不能满足日益增长的需求,此时想到服务器集群,增加服务器数量,然后将原先请求单个服务器的情况改为将请求分发到多个服务器上,将负载分发到多个服务器上,也就是我们讲的
文章图片
四、动静分离 为了加快网站的解析速度,可以把动态页面和静态页面有不同的服务器来解析,减少服务器压力,加快解析速度。
文章图片
五、原理 mater&worker
文章图片
master
接收信号后将任务分配给worker进行执行,worker可有多个。文章图片
六、worker如何工作 客户端发送一个请求到master后,worker获取任务的机制不是直接分配也不是轮询,而是一种争抢的机制,“抢”到任务后再执行任务,即选择目标服务器tomcat等,然后返回结果。
文章图片
【Nginx的基本概念和原理】worker_connection
发送请求占用了woker两个或四个连接数。
- 普通的静态访问最大并发数是:
worker_connections *worker_processes/ 2 /2/2
- 若是 HTTP 作 为反向代理来说,最大并发数量应该是
worker_connections *worker_processes/ 4 /4/4
。
优点:
- 可以使用
nginx –s reload
热部署,利用 nginx 进行热部署操作 - 每个 woker 是独立的进程,若其中一个woker出现问题,其他继续进行争抢,实现请求过程,不会造成服务中断
推荐阅读
- 一些零碎代码|分享一个会遮掩的吊炸天登录页面
- Flutter 应用程序布局的最佳实践
- 朝花夕拾 - 工作、生活的焦虑和解决
- 数据结构->顺序表的操作
- C语言拯救者|C语言拯救者 番外篇 (函数栈帧的创建和销毁讲解)
- C语言系统学习学习手册|【C语言知识精讲③】函数栈帧的创建和销毁(全程图解)
- C语言基础|【C语言】函数栈帧的创建与销毁
- c语言表白源代码
- c语言中a|c语言中a 的用法,C语言中#define的用法
- c语言中的标识符怎么表示,C语言中用宏怎么构造标识符