NGINX——负载均衡

负载均衡————>通过反向代理来实现

nginx反向代理的七层代理和四层代理

七层代理:

七层代理时最常用的反向代理方式,其只能配置在nginx的配置文件的http模块中,而且方法名称必须要定义成“upstream”模块,注意不能写在server模块中,也不能写在location模块中;

同时upstream模块在http模块中时一个独立的模块

七层代理:代理的是http的请求和响应

七层代理的工作原理:

客户端——>http请求——>七层代理(代理服务器上)——>代理服务器转发http,请求到内部的一组服务器(web集群)——>客户端不知道请求的时代里服务器还是内部服务器,而且通过代理服务器隐藏了内部服务器的ip。

        实际上访问的是代理服务器,请求到代理,由代理转发给web服务器,web服务器相应————————实际由web服务器来相应

四层代理

四层代理是基于tcp/ip协议,协议层的代理转发方式,可以实现基于ip地址和端口号进行负载均衡转发;四层代理无法获取http请求当中的URL信息,只能对tcp/udp数据包进行转发,流量转发,配置方法的名称:stream;stream不能配置在http模块中,其配置在全局模块中,属于一个独立的模块

四层代理和七层代理之间的区别(重点!!)

1、七层代理走的是http请求;而四层代理走的是tcp/udp数据包,转发的是流量;

        七层代理:http 请求,可以对请求进行深入的解析和处理。如:流量控制、内容过滤;

        四层代理:不进行流量控制,也无法对内容进行过滤;

        

        四层代理通常适用于:需要处理大量连接请求的场景

        七层代理通常适用于:对请求进行精确处理和控制的场景

                在实际工作中,四层代理和七层代理可以配合使用

2、四层代理的速度比七层代理的速度快;

        原因:

        (1):四层代理为流量转发,不能对请求进行解析和控制,所以要快

        (2):四层代理走的是内核,由内核来转发流量,速度快

      七层代理相对慢

        原因:

        (1):七层代理对请求进行处理和解析,速度慢

        (2):七层代理走的是用户态,访问控制,流量处理;所以慢

                七层代理可以提供更高的服务和更高的用户体验

正向代理与反向代理

正向代理:

模块  proxuy_pass 配置代理服务器的访问地址,此模块只能写在location模块中

反向代理:

客户端访问代理服务器,代理服务器转发请求或者流量,到后端服务器,后端的web服务器会有多台,但用户并不知道最终访问的是哪一台服务器

        反向代理的作用:负载均衡、高可用、可扩展、提高可维护性。

在工作中如何进行反向代理?

反向代理——>负载均衡

        upstream:基于http实现负载均衡,反向代理

特点:

1、http请求的负载均衡方式

2、没有缓存

3、负载均衡的算法:

(1)默认算法:轮询(rr);请求轮流分配给后端服务器,轮询算法使用于多台web服务器处理能力相近的情况,默认算法,可以不加

(2)加权算法:建立在轮询算法的基础上,通过给不同的web服务器权重,让处理能力更强的服务器可以分配到更多的请求;(注意:虽然配置了权重,但是沦陷的结果未必一直准确)

(3)ip_hash:根据IP地址计算出一个hash值,使用ip_hash算法后,同一个客户端的请求会ibei分配到同一个后端服务器,保证会话的稳定性;当后端服务器的数量发生了变化,hash的值会被重新计算,请求的服务器可能也会发生变化

(4)最少连接数:least_conn;会轮询,特点:会将请求发送到当前连接数最少的后端web服务器,适用于后端服务器处理任务耗时不同的情况,避免了所有请求都集中在处理能力更强的后端服务器上,least_conn算法会和加权轮询算法结合使用

(5)url_hash:根据URI地址计算出hash值,使用url_hash算法时,相同请求的URI会分配到同一个后端服务器

        负载均衡算法的使用场景:

        小型场景:并发量很小,默认算法就可以满足适用条件

        后端web服务器的处理能力由差异,加权轮询和最小连接数配合使用即可

        大型并发:ip_hash、url_hash;第一次请求之后会有本地缓存生成,而且因为hash算法的原因,请求的后端web服务器不会发生变化,可以提高访问速度,访问的是本地缓存。减轻了后端服务器的请求能力

        注意点:

ip_hash :当后端服务器的数量发生了变化,则请求的服务器可能会发生变化

uri_hash:当请求的地址发生了变化,请求的服务器也可能会发生变化

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/30836.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Druid,以jdbc方式配置多数据源

文章目录 背景示例代码(结合实际进行配置)总结 背景 当使用Spring Boot项目并需要多数据源时,你可以使用Druid连接池来配置和管理多个数据源。以下是一个示例的配置和代码,以说明如何实现多数据源: 示例代码&#xf…

【Mybatis】调试查看执行的 SQL 语句

1. 问题场景: 记录日常开发过程中 Mybatis 调试 SQL 语句,想要查看Mybatis 中执行的 SQL语句,导致定位问题困难 2. 解决方式 双击shift找到mybatis源码中的 MappedStatement的getBoundSql()方法 public BoundSql getBoundSql(Object para…

selenium爬虫,配置谷歌浏览器的driver

用selenium爬虫时,明明已经安装了selenium模块,程序却运行不了。在使用selenium之前必须先配置浏览器对应版本的webdriver 本文主要涉及驱动有问题driver 网上有很多手动的方法(查看谷歌浏览的版本然后在其他博主分享的webdriver中下载与自己…

Mybatis Plus条件构造器LambdaQueryWrapper

官网地址 Mybatis Plus条件构造器LambdaQueryWrapper 目前数据库数据情况,User表 iduser_namebirthdaysexaddress1张12023-08-10男123163.com2李12023-08-10女222163.com3张22023-08-10女999163.com4张32023-08-10男9994qq.com ## 简单介绍 如何使用各种场景 方法…

论文笔记:SUPERVISED CONTRASTIVE REGRESSION

2022arxiv的论文,没有中,但一作是P大图班本MIT博,可信度应该还是可以的 0 摘要 深度回归模型通常以端到端的方式进行学习,不明确尝试学习具有回归意识的表示。 它们的表示往往是分散的,未能捕捉回归任务的连续性质。…

gateway做token校验

本文使用springcloud的gateway做token校验 登录的本质&#xff1a;拿用户名和密码 换 token。 token会返回给浏览器&#xff08;存储&#xff09;&#xff0c;当访问的时候&#xff0c;携带token 发起请求。 token校验图 引入redis依赖 <dependency><groupId>or…

2000-2022年全国地级市乡村振兴测算数据(30个指标)

1、时间&#xff1a;2000-2022年 2、来源&#xff1a;城市统计NJ、各地区统计NJ 3、范围&#xff1a;地级市 4、指标&#xff1a;乡村振兴指数、人均农业机械总动力&#xff08;千瓦&#xff09;、粮食综合生产能力&#xff08;万吨&#xff09;、农业劳动生产率&#xff08…

Vue2:路由

Vue2&#xff1a;路由 Date: May 28, 2023 Sum: vue-router基本使用、高级用法 单页面应用程序 概念&#xff1a;SPA【Single Page Application】是指所有的功能都在一个html页面上实现 案例&#xff1a; 单页应用网站&#xff1a; 网易云音乐 https://music.163.com/ 多页…

Idea使用Docker插件实现maven打包自动构建镜像

Docker 开启TCP 服务 vi /lib/systemd/system/docker.service改写以下内容 ExecStart/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock重启服务 #重新加载配置文件 systemctl daemon-reload #重启服务 systemctl restart docker.service此时docker已…

大数据课程I1——Kafka的概述

文章作者邮箱&#xff1a;yugongshiyesina.cn 地址&#xff1a;广东惠州 ▲ 本章节目的 ⚪ 了解Kafka的概念&#xff1b; ⚪ 掌握Kafka的配置与启动&#xff1b; 一、简介 1. 基本概念 Apache kafka 是一个分布式数据流平台。可以从如下几个层面来理解&#x…

elasticsearch-head可视化安装

一、前言 elasticsearch-head 是用于监控 Elasticsearch 状态的客户端插件&#xff0c;包括数据可视化、执行增删改查操作等。 elasticsearch是通过API方式进行管理的&#xff0c;因此也可以使用postman等工具操作elasticsearch。 二、安装 lasticsearch-head插件是使用Jav…

C++核心编程——函数高级、类和对象

3 函数提高 3.1 函数默认参数 在C中&#xff0c;函数的形参列表中的形参是可以有默认值的。 语法&#xff1a;返回值类型 函数名 &#xff08;参数默认值&#xff09;{} 注意事项&#xff1a; 1、如果函数的参数列表中某个参数已经有了默认参数&#xff0c;那么从这个参…

cve-2021-2394 weblogic反序列化漏洞分析

前几天weblogic 7月例行更新中&#xff0c;修复了一个Rce漏洞。该漏洞性质属于绕过之前的反序列化漏洞补丁。要了解这个漏洞的原因&#xff0c;我们首先要学习其他几个漏洞的原理。 一 weblogic 反序列化绕过指南 本章节只是大概讲解一下如何绕过weblogic反序列化漏洞的补丁。…

解决selenium的“can‘t access dead object”错误

目录 问题描述 原因 解决方法 示例代码 资料获取方法 问题描述 在python执行过程中&#xff0c;提示selenium.common.exceptions.WebDriverException: Message: TypeError: cant access dead object 原因 原因是代码中用到了frame,获取元素前需要切换到frame才能定位到…

苍穹外卖day11笔记

今日首先介绍前端技术Apache ECharts&#xff0c;说明后端需要准备的数据&#xff0c;然后讲解具体统计功能的实现&#xff0c;包括营业额统计、用户统计、订单统计、销量排名。 一、ECharts 是什么 ECharts是一款基于 Javascript 的数据可视化图表库。我们用它来展示图表数…

一次面试下来Android Framework 层的源码就问了4轮

说起字节跳动的这次面试经历&#xff0c;真的是现在都让我感觉背脊发凉&#xff0c;简直被面试官折磨的太难受了。虽然已经工作了七年&#xff0c;但是也只是纯粹的在写业务&#xff0c;对底层并没有一个很深的认识&#xff0c;这次面试经历直接的让我感受到我和那些一线大厂开…

在Ubuntu系统下修改limits.conf不生效

文章目录 前言尝试过程总结 前言 最近遇到的一个问题&#xff0c;在Ubuntu系统下修改/etc/security/limits.conf不生效&#xff0c;查了多种资料都说不用重启&#xff0c;但是我改完就是不生效&#xff0c;多次尝试之后发现Ubuntu系统有毒。 尝试过程 通过 ulimit -n 命令可…

Client not connected, current status:STARTING

今天项目集成Seata时遇到一个奇怪的异常&#xff0c;在此记录一下。 Linux环境安装Seata&#xff0c;使用Nacos作为配置中心、注册中心&#xff1b; Linux已开放端口&#xff1a;8848、7091、8091 在我Windows环境下可以看到Nacos运行正常&#xff0c;Seata运行也正常&#…

【腾讯云 Cloud Studio 实战训练营】用于编写、运行和调试代码的云 IDE泰裤辣

文章目录 一、引言✉️二、什么是腾讯云 Cloud Studio&#x1f50d;三、Cloud Studio优点和功能&#x1f308;四、Cloud Studio初体验&#xff08;注册篇&#xff09;&#x1f386;五、Cloud Studio实战演练&#xff08;实战篇&#xff09;&#x1f52c;1. 初始化工作空间2. 安…

学习笔记-JAVAJVM-JVM的基本结构及概念

申明&#xff1a;文章内容是本人学习极客时间课程所写&#xff0c;文字和图片基本来源于课程资料&#xff0c;在某些地方会插入一点自己的理解&#xff0c;未用于商业用途&#xff0c;侵删。 原资料地址&#xff1a;课程资料 什么是JVM 原文连接&#xff1a; 原文连接 JVM是J…