相关文章推荐
博学的绿茶  ·  使用Resource Hacker ...·  2 月前    · 
博学的绿茶  ·  Utility Types | Vue.js·  10 月前    · 
博学的绿茶  ·  Help And Training ...·  11 月前    · 
博学的绿茶  ·  r - Caused by error ...·  1 年前    · 
文雅的沙滩裤  ·  WKWebView拦截请求资源 ·  29 分钟前    · 
独立的眼镜  ·  如何连接Babelfish for RDS ...·  2 小时前    · 
发财的蛋挞  ·  Microsoft Azure Data ...·  2 小时前    · 
冷冷的投影仪  ·  Secure an ASP.NET ...·  2 小时前    · 
不羁的生姜  ·  PSPSDK 开发的时候出现 ...·  2 小时前    · 
logo

你知道Nginx的所有功能吗?

作者: 挖掘开源的价值 2021.08.05 10:13 浏览量: 77

简介: 介绍Nginx中的所有功能

文章已同步至GitHub开源项目: Java超神之路

Nginx的概念

​ Nginx (“engine x”) 是一个高性能的 HTTP 和反向代理服务器 ,特点是占有内存少,并发能

力强,事实上 nginx 的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用 nginx

网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

Nginx作为 web 服务器

​ Nginx 可以作为静态页面的 web 服务器,同时还支持 CGI 协议的动态语言,比如 perl、php

等。但是不支持 java。Java 程序只能通过与 tomcat 配合完成。Nginx 专为性能优化而开发,

性能是其最重要的考量,实现上非常注重效率 ,能经受高负载的考验,有报告表明能支持高

达 50,000 个并发连接数。( https://lnmp.org/nginx.html)

​ Nginx 不仅可以做反向代理,实现负载均衡。还能用作正向代理来进行上网等功能。

正向代理:如果把局域网外的 Internet 想象成一个巨大的资源库,则局域网中的客户端要访

问 Internet,则需要通过代理服务器来访问,这种代理服务就称为正向代理。

​ 反向代理,其实客户端对代理是无感知的,因为客户端不需要任何配置就可以访问,我们只

需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,在返

回给客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器

地址,隐藏了真实服务器 IP 地址。

​ 客户端发送多个请求到服务器,服务器处理请求,有一些可能要与数据库进行交互,服

务器处理完毕后,再将结果返回给客户端。

 这种架构模式对于早期的系统相对单一,并发请求相对较少的情况下是比较适合的,成

本也低。但是随着信息数量的不断增长,访问量和数据量的飞速增长,以及系统业务的复杂

度增加,这种架构会造成服务器相应客户端的请求日益缓慢,并发量特别大的时候,还容易

造成服务器直接崩溃。很明显这是由于服务器性能的瓶颈造成的问题,那么如何解决这种情

 我们首先想到的可能是升级服务器的配置,比如提高 CPU 执行频率,加大内存等提高机

器的物理性能来解决此问题,但是我们知道摩尔定律的日益失效,硬件的性能提升已经不能

满足日益提升的需求了。最明显的一个例子,天猫双十一当天,某个热销商品的瞬时访问量

是极其庞大的,那么类似上面的系统架构,将机器都增加到现有的顶级物理配置,都是不能

够满足需求的。那么怎么办呢?

 上面的分析我们去掉了增加服务器物理配置来解决问题的办法,也就是说纵向解决问题

的办法行不通了,那么横向增加服务器的数量呢?这时候集群的概念产生了,单个服务器解

决不了,我们增加服务器的数量,然后将请求分发到各个服务器上,将原先请求集中到单个服务器上的情况改为将请求分发到多个服务器上,将负载分发到不同的服务器,也就是我们所说的负载均衡

 
推荐文章