前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nginx-基本概念和原理

Nginx-基本概念和原理

作者头像
唔仄lo咚锵
发布2020-09-15 15:12:24
3570
发布2020-09-15 15:12:24
举报

文章目录

  • Nginx基本概念
    • 反向代理
    • 负载均衡
    • 动静分离
  • 原理
    • mater&worker
    • worker如何工作
    • worker_connection
    • 优点

Nginx基本概念


Nginx(engine x)是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。 Nginx专为性能优化而开发,性能是器最重要的考量,实现上非常注重效率,能经受高负载的考验,据报告能支持高达50,000个并发连接数。 Nginx不仅能作反向代理,实现负载均衡;还能可以作正向代理来进行上网等功能。

反向代理


正向代理: 在客户端(浏览器)配置代理服务器,通过代理服务器进行互联网访问。代理对象是客户端,不知道服务端是谁。

在这里插入图片描述
在这里插入图片描述

反向代理 客户端不需要任何配置就能访问,只需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器,获取数据后在返回给客户端。对外就一个服务器,暴露的是反向代理服务器地址,隐藏了真实服务器IP地址。代理对象是服务端,不知道客户端是谁。

在这里插入图片描述
在这里插入图片描述

负载均衡


客户端发送多个请求到服务器,服务器处理请求,有些可能要访问数据库,服务器处理完毕后再将结果返回客户端。 这种架构模式单一,适合并发请求少的情况,但并发量大的时候如何解决?

在这里插入图片描述
在这里插入图片描述

首先可能想到升级服务器配置,但硬件的性能提升不能满足日益增长的需求,此时想到服务器集群,增加服务器数量,然后将原先请求单个服务器的情况改为将请求分发到多个服务器上,将负载分发到多个服务器上,也就是我们讲的负载均衡。

在这里插入图片描述
在这里插入图片描述

动静分离


为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,减少服务器压力,加快解析速度。

在这里插入图片描述
在这里插入图片描述

原理

mater&worker

在这里插入图片描述
在这里插入图片描述

master接收信号后将任务分配给worker进行执行,worker可有多个。

在这里插入图片描述
在这里插入图片描述

worker如何工作

客户端发送一个请求到master后,worker获取任务的机制不是直接分配也不是轮询,而是一种争抢的机制,“抢”到任务后再执行任务,即选择目标服务器tomcat等,然后返回结果。

在这里插入图片描述
在这里插入图片描述

worker_connection

发送请求占用了woker两个或四个连接数。

  • 普通的静态访问最大并发数是: worker_connections ∗ * ∗worker_processes / 2 /2 /2
  • 若是 HTTP 作 为反向代理来说,最大并发数量应该是 worker_connections ∗ * ∗worker_processes / 4 /4 /4。

当然了,worker数也不是越多越好,worker数和服务器的CPU数相等时最适宜的。

优点

  1. 可以使用 nginx –s reload 热部署,利用 nginx 进行热部署操作
  2. 每个 woker 是独立的进程,若其中一个woker出现问题,其他继续进行争抢,实现请求过程,不会造成服务中断

原创不易,请勿转载本不富裕的访问量雪上加霜 ) 博主首页:https://blog.csdn.net/qq_45034708

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • Nginx基本概念
    • 反向代理
      • 负载均衡
        • 动静分离
        • 原理
          • mater&worker
            • worker如何工作
              • worker_connection
                • 优点
                相关产品与服务
                负载均衡
                负载均衡(Cloud Load Balancer,CLB)提供安全快捷的流量分发服务,访问流量经由 CLB 可以自动分配到云中的多台后端服务器上,扩展系统的服务能力并消除单点故障。负载均衡支持亿级连接和千万级并发,可轻松应对大流量访问,满足业务需求。
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档