我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Nginx简介

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Nginx简介

一、什么是Nginx?

Nginx是一个高性能的HTTP和反向代理Web服务器,同时也提供IMAP/POP3/SMTP服务。Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3/SMTP)代理服务器。Nginx的特点是:占有内存少,并发能力强。

Nginx专门为性能优化而开发,性能是最重要的考量,非常注重效率,事实上Nginx的并发能力在同类型的网页服务器种表现较好,能够支持高达50000个并发连接响应数。

二、Nginx相关概念

① 代理(正向代理、反向代理)

Ⅰ、正向代理

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

客户端(浏览器)配置代理服务器,通过代理服务器进行互联网访问,这个过程就是正向代理。

Ⅱ、反向代理

概念:反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源。

反向代理,其实对于客户端来说,对代理是无感知的,因为客户端不需要任何配置就可以访问。

过程:反向代理时,我们只需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,将数据返回给客户端,此时反向代理服务器和目标服务器在外界看来就是一个服务器,暴露的是代理服务器,隐藏了真实服务器的IP地址。

端口号为5173的反向代理服务器根据客户端的请求,将请求转发到目标服务器的Tomcat中,但是在这个过程中,客户端直接访问的是端口号为5173的反向代理服务器,而不是Tomcat服务器,所以对外暴露的是反向代理服务器,而真正的内部服务器是端口号为8080的Tomcat。从客户端来看,客户端并不知道有反向代理服务器的存在,所以在外部看来,反向代理服务器5173和Tomcat服务器8080好像是一个服务器,也就是对外就是一个服务器。

② 负载均衡

概念:负载均衡其意思就是分摊到多个操作单元上进行执行,从而共同完成工作任务。

客户端发送请求到服务器,服务器处理请求,与数据库交互,服务区处理完成后,将结果响应给客户端。

这是一个请求的正常流程,但是当今信息量不断增加,如果还是依靠于这种架构模式,就会产生很多问题,那么该如何解决?

我们首先想到的是提高服务器、数据库的配置,但是硬件提升也不是无限度的,所以我们可能需要另辟蹊径来解决。既然单个服务器解决不了,那么我们就增加服务器的数量,然后将各个不同的请求分发到各个服务器上,减少一个服务器的请求数,将负载(请求)分发到不同服务器上,也就是我们所说的负载均衡。

客户端发送N条请求,上面我们了解到Nginx可以做反向代理,所以在这里,用户请求可以通过反向代理服务器,将N条请求平均分发到不同的服务器,不同端口号的服务器会得到反向代理服务器分发到不同请求信息进行处理。(当然,不同服务器处理的请求数量需要根据实际情况来定,均分处理请求是理想情况)

负载均衡的分配策略

Ⅰ、轮询策略(负载均衡默认的分配策略)

将用户的请求轮流分配给服务器,就像是挨个数数,轮流分配。如果后端有服务器宕机了,就会自动剔除。

upstream myserver {    server 192.168.220.120:8080;    server 192.168.220.120:8081;}
Ⅱ、weight策略(权重策略)

简而言之,就是当weight(权重)越高时,被分配的用户请求就会越多。

upstream myserver {    server 192.168.220.120:8080 weight=1;    server 192.168.220.120:8081 weight=5;}
Ⅲ、ip_hash策略

每个请求访问会根据ip地址的hash结果进行分配,这样每个用户就会固定访问一个后端服务器,也就是只要用户的ip地址不发生改变,那会对应后续访问的后端服务器就不会发生变化,可以解决session的问题。

upstream myserver {    ip_hash;    server 192.168.220.120:8080;    server 192.168.220.120:8081;}
Ⅳ、fair策略(第三方)

按后端服务器的响应时间来分配,响应时间短的优先分配。比如,当客户端发出请求后,Nginx负载均衡,转发请求到后端服务器中,后端服务器后很多(比如:A服务器、B服务器……等等),其中如果B服务器响应速度最快,也就是响应时间最短,那么就会将请求转发给B服务器。

upstream myserver {    server 192.168.220.120:8080;    server 192.168.220.120:8081;    fair;}

③ 动静分离

概念:动静分离是指在web服务器架构中,将静态页面与动态页面或者静态内容接口和动态内容接口分开不同系统访问的架构设计方法,进而提升整个服务访问性能和可维护性。

动静分离可以加快网站的解析速度,把动态页面和静态页面交由不同的服务器来解析,加快了解析速度,同时也降低了原来单个服务器的压力。

最初,我们在项目加载时,会将动态、静态资源全部加载到Tomcat服务器中(这里用Tomcat举例),这无疑会增加Tomcat服务器的运行压力。

所以,我们想出来一种方式,来减小服务器的压力,也就是动静分离。

此时,我们会将动态资源放入到Tomcat服务器中,将静态资源放到静态资源服务器中,如果客户端请求动态或静态资源,那么反向代理服务器就会向Tomcat服务器或者静态资源服务器中分别分发请求,同时也减轻了服务器的压力。我们可以看到,动静分离是将动态请求与静态请求分开,不能简单的理解为只是将动态页面和静态页面分离开。

实现动静分离的两种方式

① 把静态文件独立成单独的域名,放在独立的服务器上。(目前主流)
② 把静态文件和动态文件混合放在一起,通过Nginx来去分开。

④ 高可用

通过上面相关概念的分析,我们可以看到Nginx服务器有很多好处(我们这里用Tomcat举例),Tomcat如果宕机后,Nginx会做出相应的反应,但是如果Nginx宕机了,此时用户发送请求,是无法收到响应的,我们这时该怎么办?

我们此时就需要配置成一个高可用的效果,那么什么是高可用?也就是如果Nginx宕机后,用户的请求不会受到影响,仍然可以正常使用,这就是高可用。高可用的效果是怎样的呢?

我们此时会有一台Nginx的主服务器,和一台Nginx的备份务器,一般情况下,当主服务器正常运行时,用户请求会经过主服务器分发请求到各个服务器上。但是当主服务器宕机后,这时就会自动切换到备份服务器,通过备份服务器来完成用户的请求,此时,备份服务器作为主服务器来完成用户请求,这就是高可用的一个效果。我们实现这个过程,需要用到一个软件,叫做keepalived,它会通过脚本来进行检测Nginx服务器是否还存活,如果宕机了,就会自动切换到备份服务器。但是,我们可以看到一个问题,不同的Nginx服务器的ip是不同的,所以我们此时需要对外提供虚拟ip,将虚拟ip绑定到两台Nginx服务器上,keepalived在这个过程中起到一个路由的作用。也就是说,keepalived在这个过程中会检测是否存活,如果主服务器宕机后,keepalived会将虚拟ip绑定到备份服务器中,所以,总的来说,作为用户,都是通过这个虚拟ip来进行的访问。(主服务器以及备份服务器都需要keepalived)

来源地址:https://blog.csdn.net/weixin_52772307/article/details/128576305

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Nginx简介

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

2023-10-11

MongoDB(一):NoSQL简介、MongoDB简介

1. NoSQL简介1.1 什么是NoSQLNoSQL(NoSQL= Not Only SQL),意即“不仅仅是SQL",是一项全新的数据库理念,泛指非关系型的数据库。1.2 为什么需要NoSQL随着互联网web2.0网站的兴起,非关系型的数据库现在成了一个极
MongoDB(一):NoSQL简介、MongoDB简介
2019-07-31

nginx介绍及配置

Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器。Nginx的特点是占用内存少,并发能力强。它可以在大量的并发连接下保持低CPU和内存占用,同时还能保持高效的反向代理和负载均衡。Nginx的配置文
2023-09-09

Elasticsearch简介

疫情已经持续了好几个月了,作为程序员滴我们也帮不上什么忙,只有老老实实呆在家里或者出门一定戴口罩准守一些规则,不给国家添乱。不过最近疫情开始有所扭转,但是还是对国家经济,对企业业务造成了很大的影响,我也被停止了实习。接下来,可能会面临着失业,破产等等严肃的问题
Elasticsearch简介
2014-08-14
2024-04-02

VMotion简介

源起:
2023-06-04

MySQL简介

MySQL介绍:简介、特点与应用示例概述:MySQL是当前最常用的关系型数据库管理系统之一。作为一个开源的数据库管理系统,MySQL具有许多优点,如高性能、可靠性强以及易于使用等。本文将介绍MySQL的特点以及应用场景,并附上相关代码示例
MySQL简介
2024-02-22

Hive简介

1.1  Hive简介1.1.1 什么是HiveHive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供类SQL查询功能。1.1.2 为什么使用Hive直接使用hadoop所面临的问题人员学习成本太高项目周期要求太短Map
Hive简介
2019-06-16

Redis 简介

Redis 特性     1.速度快       官方给出的数字是读写性能可以达到10万/秒,当然这也取决于机器的性能。大致归纳速度快的四点原因如下:             # Redis 的所有数据都是放在内存中的,这也是最主要的原因;          
Redis 简介
2021-08-02

Cassandra 简介

Cassandra是云原生和微服务化场景中最好的NoSQL数据库。我信了~ 1. Cassandra是什么高可用性和可扩展的分布式数据库Apache Cassandra™是一个开源分布式数据,可提供当今最苛刻的应用程序所需的高可用性、高性能和线性可伸缩性。它提
Cassandra 简介
2015-01-20
2023-09-01
2023-09-03

python简介

Python是一种开源的面向对象编程语言随着人工智能与大数据分析的火热,python也随之火热起来Python应用广泛,特别适用以下几个方面1.系统编程:提供API(Application Programming Interface,应用程
2023-01-30

Python 简介

Python介绍与特点(自学python知识整理)Python 是一个高层次的结合了解释性、编译性、互动性和面向对象的脚本语言。Python 的设计:Python 是一种解释型语言: 这意味着开发过程中没有了编译这个环节。类似于PHP和Pe
2023-01-31

IPv6简介

IPv6仅仅只是“长”吗?IPv6的地址长什么样?平时我们是怎么使用IPv6的呢?编写网络程序的时候要怎么处理IPv6?且待本篇一一道来。为什么需要IPv6?全球的IP地址由一个名字叫IANA(Internet Assigned Numbe
2023-01-31

Redis简介

Redis官方网网站是:http://www.redis.io/ 。 Redis是一个开源,高级的键值存储和一个适用的解决方案,用于构建高性能,可扩展的Web应用程序。 Redis有三个主要特点,使它优越于其它键值数据存储系统 : a.Re
2022-06-04

编程热搜

目录