位置: IT常识 - 正文

图解Nginx,系统架构演变 + Nginx反向代理与负载均衡(nginx gui)

编辑:rootadmin
图解Nginx,系统架构演变 + Nginx反向代理与负载均衡

推荐整理分享图解Nginx,系统架构演变 + Nginx反向代理与负载均衡(nginx gui),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nginxe,nginx简介,nginx原理图解,nginx最全教程,nginx操作系统,nginx gui,nginx原理图解,nginx操作系统,内容如对您有帮助,希望把文章链接给更多的朋友!

目录专栏导读一、系统架构演变二、什么是Nginx?三、servername匹配规则四、正向代理与反向代理1、正向代理2、反向代理3、LVS五、负载均衡策略1、轮询2、权重3、ip_hash4、least_conn5、url_hash6、fair7、小结六、动静分离七、URLRewrite专栏导读

🏆作者简介:哪吒,CSDN2022博客之星Top1、CSDN2021博客之星Top2、多届新星计划导师✌、博客专家💪 ,专注Java硬核干货分享,立志做到Java赛道全网Top N。

🏆本文收录于Java基础教程系列(进阶篇),本专栏是针对大学生、初级Java工程师精心打造,针对Java生态,逐个击破,不断学习,打通Java技术栈。

🏆订阅后,可以阅读Java基础教程系列(进阶篇)中全部文章,包含Java基础、Java高并发、Spring、MySQL等Java进阶技术栈。

🏆还可以订阅其姐妹篇,Java基础教程系列,包含全部Java基础知识点、Java8新特性、Java集合、Java多线程、Java代码实例,理论结合实战,实现Java的轻松学习。

🏆哪吒多年工作总结:Java学习路线总结,搬砖工逆袭Java架构师。

🏆面试福音:10万字208道Java经典面试题总结(附答案)

大家好,我是哪吒。

本系列为SpringCloud微服务系列,先从微服务的入口Nginx开始学习,读哪吒编程,品技术人生。

一、系统架构演变

最开始接触Java语言的时候,我写的第一个项目是图书管理系统,当时是用JSP+servlet写的,感觉很吊的样子,全班领先水平。

慢慢的变成了JSP+SSM架构。 到现在单体架构最流行的SpringBoot+Vue。 但是,随着业务量的不断增大,你会发现,这些单体架构,已经无法满足数据日益膨胀的今天,动不动就几万、几十万的QPS,我记得当初200QPS,我就觉得挺吓人了。

为了解决性能问题,慢慢的微服务SpringCloud架构浮出水面,微服务的核心理念是将应用细粒化,将单一应用拆分成若干个小应用,每个小应用提供单一的业务功能,独立部署,服务之间相互调用,降低程序耦合度,解决单台服务器宕机的问题。

微服务提供了:

高可用:当某个节点服务器宕机后,可以迅速将流量转移到其它节点;高性能:多台服务器对外提供相同的服务,提升程序的吞吐量;高扩展:当业务发生激增时,可以通过增加节点的方式,解决性能问题​;

注:本章的重点是Nginx,微服务其它组件就不画了。

二、什么是Nginx?

Nginx是俄罗斯人Igor Sysoev编写的一款高性能 HTTP 和反向代理服务器。Nginx选择了epoll和kqueue作为网络I/O 模型,在高连接并发的情况下,Nginx是Apache服务器不错的替代品,它能够支持高达50 000个并发连接数的响应,运行稳定,且内存、CPU等系统资源消耗非常低。

三、servername匹配规则完整匹配通配符匹配正则匹配

正则匹配格式,必须以~开头,比如server_name ~^www\d+\.nzbc\.com$;。如果没有~开头,则Nginx会判定为完整匹配,在逻辑上,需要添加^和$锚定符号。正则匹配格式中.为正则元字符,需要通过反斜线进行转义,如果正在表达式中包含{},需要用双引号引用起来,避免报错。

四、正向代理与反向代理1、正向代理

正向代理服务器一般位于用户和服务器之间,用户通过正向代理服务器访问应用服务器获取资源。

最常见的例子就是,我们访问一个外国网站,该网站无法在国内直接访问,但是可以通过代理服务器访问,也就是说,用户向正向代理服务器发送一个请求并指定目标,然后正向代理服务器向目标服务器(外国网站)转交请求并将获得的内容返回给用户。

正向代理服务器,代理的是客户端,去和服务端交互。

2、反向代理

反向代理服务器一般位于用户和服务器之间,用户访问反向代理服务器获取应用服务器资源,用户不知道应用服务器的地址,是由代理服务器转发的,有降低网络和服务器的负载,提高访问效率的作用。

反向代理服务器,代理的是服务端,去和客户端交互。

Nginx就是一款高性能的反向代理服务器。

3、LVS

先说结论,LVS解决了Nginx单机性能瓶颈的问题。

LVS主要用于多服务器负载均衡,工作在网络的第四层,可以实现高性能、高可用的服务器集群技术,采用同步请求转发的策略。

LVS支持的并发量要比Nginx高,可以配合keepalived使用,将Nginx作为LVS的节点机器,因为Nginx在网络的第七层,功能上肯定强于LVS。

图解Nginx,系统架构演变 + Nginx反向代理与负载均衡(nginx gui)

用户通过Nginx访问应用服务器,应用服务器直接将数据返回给机房路由,返回时不走Nginx了,降低了Nginx的性能消耗。

五、负载均衡策略1、轮询

默认使用轮询方式,逐一转发访问,这种情况适合无状态请求,会话无法保持,可以通过基于客户端实现会话保持。

会话保持方式:

(1)基于session实现:

session用于存储客户端用户信息,一般不在服务器存储session,可以通过SpringSession将session存储到一个Redis服务器中,再次访问时,可以到Redis服务器中获取session,实现session共享。

(2)基于cookie实现,无状态的会话保持方式:

客户端访问时,先到权限校验服务器校验权限,生成一个cookie,并进行加密,只有服务器能解密,客户端没密码无法解密,客户端携带此cookie再次访问应用服务器,应用服务器进行解密校验,完成无状态的会话保持。

2、权重

通过upstream进行权重的定义。

weight:权重down:下线不用了backup:备用服务器

修改配置文件后,需要通过systemctl reload nginx命令重启Nginx。

nginx.conf配置如下

http{upstream httpnz {server 192.168.66.1 weight=1 down;server 192.168.66.2 weight=5 backup;server 192.168.66.3 weight=10;}server{listen 80;server_name nzbc;location / {proxy_pass http://httpnz;}error_page 500.html;location = /500.html{root html;}}}3、ip_hash

每个请求按访问ip的hash结果分配,映射到固定某一台的服务器,会导致负载均衡不平衡。

当此应用服务器宕机后,session会丢失,再次发起请求时,会重新固定访问另一台正常的应用服务器,并实现会话保持。

4、least_conn

最少连接访问。

5、url_hash

根据访问的url转发请求,定向流量转发。

每个请求按访问url的hash结果分配,映射到固定的某一台服务器,会话无法保持。

一般在获取本地资源时使用(且本地资源不在同一台服务器上),比如通过地址1获取图片资源、通过地址2获取pdf协议资源。

6、fair

根据服务器响应时间转发请求。

7、小结

最常用的负载均衡策略是配置权重,其它的形式,不是很常用。

ip_hash、least_conn、url_hash、fair,这几种形式无法实现动态Nginx上下线(新增或减少Nginx服务器),而且还会造成流量倾斜的问题,如果瞬时流量比较爆炸的时候,会将某个服务器直接干蹦。

六、动静分离

动静分离的最终目的是将获取静态资源和动态资源分离开,提升服务器性能和高可用性。

配置静态资源,nginx.conf配置如下

http{upstream httpnz {server 192.168.66.1 weight=1 down;server 192.168.66.2 weight=5 backup;server 192.168.66.3 weight=10;}server{listen 80;server_name nzbc;location / {proxy_pass http://httpnz;}location ~*/(js/img/css) {root html;index index.html index.htm;}error_page 500 502 503 504 /50x.html;location = /50x.html{root html;}}}七、URLRewrite

URLRewrite是实现URL重写的关键指令,根据regex (正则表达式)部分内容,重定向到replacement,结尾是flag标记。

flag标记说明:

break,本条匹配完成后即终止;last,本条匹配完成后,继续向下匹配;redirect,返回302临时重定向;permanent,返回301永久重定向;

配置URLRewrite,nginx.conf配置如下

http{upstream httpnz {server 192.168.66.1 weight=1 down;server 192.168.66.2 weight=5 backup;server 192.168.66.3 weight=10;}server{listen 80;server_name nzbc;location / {rewrite ^/([0-9]+).html$ /index.jsp?pageNum=$1 break;proxy_pass http://httpnz;}location ~*/(js/img/css) {root html;index index.html index.htm;}error_page 500 502 503 504 /50x.html;location = /50x.html{root html;}}}

Java学习路线总结,搬砖工逆袭Java架构师

10万字208道Java经典面试题总结(附答案)

Java基础教程系列

Java基础教程系列(进阶篇)

本文链接地址:https://www.jiuchutong.com/zhishi/299642.html 转载请保留说明!

上一篇:【人工智能与深度学习】监督方法的成功故事: 前置训练(人工智能 深度)

下一篇:9-数据结构-单链表头插法尾插法(数据结构的单链表)

  • 华为gt3pro屏幕分辨率(华为gt3pro功能)

    华为gt3pro屏幕分辨率(华为gt3pro功能)

  • 华为matepad11可以插电话卡吗(华为matepad11可以连接键盘吗)

    华为matepad11可以插电话卡吗(华为matepad11可以连接键盘吗)

  • 蚂蚁庄园收麦子怎么收(蚂蚁庄园收麦子别人会知道吗)

    蚂蚁庄园收麦子怎么收(蚂蚁庄园收麦子别人会知道吗)

  • ipad怎么投屏到电脑(ipad怎么投屏到电视机)

    ipad怎么投屏到电脑(ipad怎么投屏到电视机)

  • 美团信任分怎么开通(美团信任分怎么看涨了还是降了)

    美团信任分怎么开通(美团信任分怎么看涨了还是降了)

  • excel表格怎样筛选出重复的内容(excel表格怎样筛选)

    excel表格怎样筛选出重复的内容(excel表格怎样筛选)

  • 5mhz等于多少hz(1.5mhz等于多少hz)

    5mhz等于多少hz(1.5mhz等于多少hz)

  • 抖音为什么很多作品不能显示了(抖音为什么很多人关注我)

    抖音为什么很多作品不能显示了(抖音为什么很多人关注我)

  • plc的软件系统可分为哪两大部分(plc的软件系统可分为应用软件)

    plc的软件系统可分为哪两大部分(plc的软件系统可分为应用软件)

  • 手机开视频发烫是什么原因(手机开视频发烫是电池的问题吗)

    手机开视频发烫是什么原因(手机开视频发烫是电池的问题吗)

  • 设置工作表保护密码是怎么完成的(设置工作表保护的两种方法)

    设置工作表保护密码是怎么完成的(设置工作表保护的两种方法)

  • 苹果x圆球怎么调出来(iphonex圆球在哪儿设置)

    苹果x圆球怎么调出来(iphonex圆球在哪儿设置)

  • 打印机主机名指的是什么(打印机主机名称是什么)

    打印机主机名指的是什么(打印机主机名称是什么)

  • 手提电脑可以连接不知道密码的无线吗(手提电脑可以连接手机热点吗)

    手提电脑可以连接不知道密码的无线吗(手提电脑可以连接手机热点吗)

  • 华为手机桌面透明度设置在哪(华为手机桌面透明图标怎么恢复)

    华为手机桌面透明度设置在哪(华为手机桌面透明图标怎么恢复)

  • 微型机一般按什么进行分类(微型机分为哪几大类,各有何特点)

    微型机一般按什么进行分类(微型机分为哪几大类,各有何特点)

  • 抖音点赞立马取消能看见吗(抖音点赞立马取消有显示吗)

    抖音点赞立马取消能看见吗(抖音点赞立马取消有显示吗)

  • ps如何镜像翻转(ps如何镜像翻转身份证)

    ps如何镜像翻转(ps如何镜像翻转身份证)

  • iphone5怎么设置控制中心(iphone5怎么设置悬浮球)

    iphone5怎么设置控制中心(iphone5怎么设置悬浮球)

  • wps中哪里有触发器(wps如何设置触发)

    wps中哪里有触发器(wps如何设置触发)

  • 直播小窗口如何设置(直播小窗口如何放大)

    直播小窗口如何设置(直播小窗口如何放大)

  • 荣耀20pro怎么卸载软件(荣耀20怎么卸载东西)

    荣耀20pro怎么卸载软件(荣耀20怎么卸载东西)

  • 手机b站怎么举报视频(b站app怎么举报)

    手机b站怎么举报视频(b站app怎么举报)

  • word乱码怎么办(qq打开word乱码怎么办)

    word乱码怎么办(qq打开word乱码怎么办)

  • 小米月亮模式怎么开(小米手机月亮模式是什么意思)

    小米月亮模式怎么开(小米手机月亮模式是什么意思)

  • mac如何做热点?mac创建wifi热点方法介绍(mac怎么创建热点)

    mac如何做热点?mac创建wifi热点方法介绍(mac怎么创建热点)

  • Windows11防火墙怎么关闭? win11关闭防火墙的技巧(w11系统防火墙)

    Windows11防火墙怎么关闭? win11关闭防火墙的技巧(w11系统防火墙)

  • Echarts直角坐标系x轴y轴属性设置大全(echart横坐标)

    Echarts直角坐标系x轴y轴属性设置大全(echart横坐标)

  • 前端基础,超全html常用标签大汇总(前端的基础知识)

    前端基础,超全html常用标签大汇总(前端的基础知识)

  • 所得税费用的计提
  • 政府返还土地款的会计处理
  • 什么是消费税?特征有哪些
  • 公司网站建设费做账是流量应计入
  • 购入土地使用权以什么为计税依据
  • 应交增值税和应交税费
  • 打印复印费的明细怎么开?
  • 收到物业费普通发票做账
  • 购买商品加包装后出售账务处理
  • 退货的产品会重新包装吗
  • 免税申请怎么办理
  • 普票记账联可以报销吗
  • 建安业一般纳税人企业所得税率是多少
  • 北京房产税如何申报缴纳
  • 纳税人财务核算及申报纳税情况报告
  • 企业取得的土地使用权用于出租或增值目的时
  • 代理记账公司收费标准
  • 退了货的发票还能用吗
  • 低价销售存货的企业所得税怎么算
  • 交易性金融资产公允价值变动计入
  • 公司0申报怎么做账
  • 公司的职工教育是指什么
  • 合伙企业收到分红需要交所得税吗
  • pop是什么文件
  • 在建工程如何转为成本费用
  • 应收票据与应付票据的使用与哪种银行结算方式有关
  • php教程100
  • 爱德华多·阿涅利
  • 企业的生产环节
  • php数组按照某个字段排序
  • 列表定义格式
  • 公司的内账
  • 应交增值税进项税额月底怎么处理
  • 在建工程减值准备是否可以转回
  • 公司进行清算
  • centos上安装vscode
  • Apache RocketMQ 5.0 笔记
  • 建筑公司多个项目分别选计税方法的适用文件
  • 小额支出的两种形式
  • 结转成本注意事项
  • 公立医院事业单位工作人员招聘实践考核自我评价
  • 残保金提取是什么意思
  • 跨年发生退货税务处理
  • 预付款项核销
  • 什么是存货周转天数
  • 税款返点如何做账务处理
  • 投资性房地产如何进行初始计量
  • 劳务公司发放农民工工资要交个税吗
  • 无形资产摊销费怎么算
  • mysql绿色版和安装版有什么区别
  • mac mysql密码
  • win8系统怎么清理磁盘
  • 使用二氧化碳灭火器时人应该站在什么位置
  • 进程是什么 进程类型
  • 电脑卡 硬盘100%
  • ubuntu linux
  • linux系统中make的用法
  • 标记不能
  • win8跳过开机密码
  • Win7系统如何打开摄像头
  • bootstrap 图表插件
  • EXTjs4.0的store的findRecord的BUG演示代码
  • 浅析学校德育的个体智能发展功能
  • linux编译链接命令
  • css中文字垂直排列
  • shell命令大全shell脚本编程100例
  • Compact 显示和更改 NTFS 分区上的文件或目录压缩
  • 究竟什么是幸福
  • cmd下copy命令
  • javascript例题
  • shell 捕获输出结果
  • 原生js常用的方法
  • 国家税务总局2012年20号公告
  • 中国有多少人2022
  • 增值税报表进项税和销项税都不填可以吗
  • 税务青年要担当
  • 党员逝世可否盖党旗
  • 重庆国税官网网址
  • 党费减免规定
  • 年度营业账簿印章怎么写
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设