【负载均衡】这些内容你需要知道下

😄作者简介: 小曾同学.com,一个致力于测试开发的博主⛽️,主要职责:测试开发、CI/CD
如果文章知识点有错误的地方,还请大家指正,让我们一起学习,一起进步。
😊 座右铭:不想当开发的测试,不是一个好测试✌️。
如果感觉博主的文章还不错的话,还请点赞、收藏哦!👍

文章目录

  • 一 🚗 什么是负载均衡
  • 二 🤫 负载均衡的作用
  • 三 🐮负载均衡的原理
  • 四 🏠负载均衡算法
  • 五 Go语言实现负载均衡
  • 六 🎬负载均衡应用场景
  • 小结

在日常开发中遇到负载均衡方面的知识,无论是分布式,中间件,还是微服务,都需要涉及到负载均衡,索性就整理下,以备不时之需。

一 🚗 什么是负载均衡

负载均衡是一种在计算机网络和服务器集群中分配工作负载的技术,将工作负载均匀地分布到多个服务器上,确保每个服务器的负载相对均衡。在一个高流量的网络环境中,单个服务器可能无法满足所有用户的请求,这可能导致性能下降、响应时间延迟或服务不可用的情况。
在这里插入图片描述

二 🤫 负载均衡的作用

  • 提高性能:负载均衡可以将请求均匀地分配到多个服务器或节点上,避免某个节点过载而导致性能下降。通过分流请求,负载均衡可以最大限度地利用系统资源,提高系统的响应速度和吞吐量。
  • 提高可靠性:通过将请求分发到多个服务器上,负载均衡可以实现冗余和故障恢复。当某个服务器发生故障时,负载均衡可以自动将请求转发到其他可用的服务器,确保服务的连续性和可用性。
  • 实现扩展性:随着业务的增长,服务器的负载也会增加。负载均衡可以通过增加更多的服务器来扩展系统的容量,使系统能够处理更多的请求和流量。通过动态地添加和移除服务器,负载均衡可以根据当前的负载情况进行自适应调整,以满足系统的需求。
  • 简化管理:负载均衡器可以作为一个中心化的调度和管理节点,统一管理和监控系统中的服务器。管理员可以通过负载均衡器进行配置和管理,而无需直接操作每个服务器,从而简化了系统的管理和维护工作。

三 🐮负载均衡的原理

负载均衡的工作原理大致可以分为以下几个步骤:

  1. 监听和接收请求:负载均衡器作为网络入口,监听来自客户端的请求。它可以通过虚拟IP(VIP)或域名来公开服务。
  2. 选择合适的服务器:负载均衡器使用特定的算法和策略来选择合适的服务器来处理请求。这些算法和策略可以基于服务器的负载情况、响应时间、连接数等因素进行选择。
  3. 分发请求:一旦负载均衡器选择了目标服务器,它会将请求转发到该服务器。转发可以通过网络层(如IP层)或应用层(如HTTP层)进行。
  4. 处理请求:目标服务器接收到请求后,根据请求的内容进行处理,并生成响应。
  5. 返回响应:目标服务器将生成的响应发送回负载均衡器。
  6. 将响应传递给客户端:负载均衡器将目标服务器返回的响应传递给相应的客户端。

四 🏠负载均衡算法

可以分为两种:静态算法和动态算法

  1. 静态算法:静态算法是负载均衡配置阶段确定的固定算法,不会根据服务器状态或负载情况进行调整。分配规则是静态的,不会根据实时情况作出变化,缺点就是无法适应动态变化的负载。

    • 轮询算法(Round Robin):按照顺序将请求依次分配给后端服务器。每个请求按照轮询顺序依次分发到不同的服务器,实现请求均衡分配。
    • 加权轮询算法(Weighted Round Robin)算法:
  2. 动态算法:动态算法是根据实时服务器状态和负载情况动态调整请求的分配。它们可以根据服务器的负载情况自适应地调整请求分发策略,以实现更好的负载均衡效果。

    • 最少连接(Least Connection)算法:将请求发送到当前连接数最少的服务器。这样可以确保负载较轻的服务器获得更多请求,从而平衡服务器的负载。
    • 响应时间加权(Response Time Weighted)算法:根据服务器的平均响应时间来分配请求。响应时间较低的服务器将获得更多的请求,以提供更快的响应。

五 Go语言实现负载均衡

在 Go 语言中实现负载均衡可以利用其并发和网络编程的特性。以下是一个简单的示例,展示了如何使用 Go 实现基于轮询的负载均衡。

package main

import (
	"fmt"
	"net/http"
	"net/http/httputil"
	"net/url"
)

var targets = []string{
	"http://localhost:8000",
	"http://localhost:8001",
	"http://localhost:8002",
}

func main() {
	// 创建反向代理器
	proxy := NewLoadBalancer(targets)

	// 启动负载均衡器服务器
	http.HandleFunc("/", proxy.Handler)
	if err := http.ListenAndServe(":8080", nil); err != nil {
		fmt.Println(err)
	}
}

// LoadBalancer 负载均衡器结构体
type LoadBalancer struct {
	targets []*url.URL
	index   int
}

// NewLoadBalancer 创建负载均衡器
func NewLoadBalancer(targets []string) *LoadBalancer {
	lb := &LoadBalancer{}
	for _, target := range targets {
		u, _ := url.Parse(target)
		lb.targets = append(lb.targets, u)
	}
	return lb
}

// Handler 负载均衡请求处理器
func (lb *LoadBalancer) Handler(w http.ResponseWriter, r *http.Request) {
	// 轮询选择目标服务器
	target := lb.targets[lb.index]
	lb.index = (lb.index + 1) % len(lb.targets)

	// 创建反向代理
	proxy := httputil.NewSingleHostReverseProxy(target)

	// 更改请求头中的主机信息
	r.URL.Host = target.Host
	r.URL.Scheme = target.Scheme
	r.Header.Set("X-Forwarded-Host", r.Header.Get("Host"))

	// 执行反向代理
	proxy.ServeHTTP(w, r)
}

在上述示例中,我们创建了一个名为 LoadBalancer 的结构体,其中包含一个目标服务器列表和一个索引变量。NewLoadBalancer 函数用于初始化负载均衡器,并将目标服务器的 URL 存储在 targets 列表中。Handler 函数是负载均衡请求的处理器,它使用轮询算法选择下一个目标服务器,并创建反向代理对象。最后,我们使用 http.ListenAndServe 启动负载均衡器服务器,并将请求转发给选择的目标服务器。

六 🎬负载均衡应用场景

适用于许多不同的系统和网络环境。以下是一些常见的负载均衡应用场景:

  1. Web 服务器:在 Web 应用程序中,负载均衡用于分发和平衡进入的 HTTP 请求,以确保服务器能够处理大量的并发请求。通过将请求分发到多个后端服务器(如应用服务器集群),负载均衡可以提高系统的可用性、性能和吞吐量。
  2. 数据库服务器:在具有高负载的数据库环境中,负载均衡可以用于将数据库请求分发到多个数据库服务器上,以实现数据库的水平扩展和负载分担。这有助于提高数据库的性能、可伸缩性和容错能力。
  3. 应用程序服务器集群:在大规模应用程序中,负载均衡可用于分发用户请求到多个应用程序服务器上,实现请求处理的并行处理和负载分担。这有助于提高应用程序的性能、可扩展性和容错能力。
  4. 网络流量路由:在网络环境中,负载均衡可用于将网络流量分发到不同的网络路径、链路或节点上,以实现流量的均衡分配和优化网络资源的利用。这有助于提高网络的可用性、带宽利用率和故障恢复能力。
  5. 媒体流服务:在流媒体应用中,负载均衡可以用于分发媒体流到多个流媒体服务器上,以实现高并发的流媒体传输和负载分担。这有助于提供稳定的媒体服务、减少延迟和提高用户体验。

总的来说,负载均衡适用于任何需要分发和处理大量请求或数据的系统和网络环境。它可以提高系统的可用性、性能和扩展性,同时平衡资源利用和减轻单个节点的负载压力。

小结

在本篇文章中我们了解到负载均衡的概念,原理已经负载均衡常用的算法,以及负载均衡的应用,当然也用go为大家展示了负载均衡的使用。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Golang并发模型:Goroutine 与 Channel 初探

文章目录 goroutinegoexit() channel缓冲closerangeselect goroutine goroutine 是 Go 语言中的一种轻量级线程(lightweight thread),由 Go 运行时环境管理。与传统的线程相比,goroutine 的创建和销毁的开销很小,可以…

Python基于jieba+wordcloud实现文本分词、词频统计、条形图绘制及不同主题的词云图绘制

目录 序言:第三方库及所需材料函数模块介绍分词词频统计条形图绘制词云绘制主函数 效果预览全部代码 序言:第三方库及所需材料 编程语言:Python3.9。 编程环境:Anaconda3,Spyder5。 使用到的主要第三方库:…

【Leetcode】【实现循环队列】【数据结构】

代码实现: typedef struct {int front;int back;int k;int* a;} MyCircularQueue;bool myCircularQueueIsEmpty(MyCircularQueue* obj) {return obj->frontobj->back; }bool myCircularQueueIsFull(MyCircularQueue* obj) {return (obj->back1)%(obj->…

位图和布隆过滤器

目录 一. 位图 1.题目: 给40亿个不重复的无符号整数,没排过序。给一个无符号整数,如何快速判断一个数是否在这40亿个数中? 2.解析题目: 3.位图 4.代码以及测试 5.其他题目 二.布隆过滤器 1.介绍 2.实现 …

Vue服务端渲染——同构渲染

Vue.js 可以用于构建客户端应用程序,组件的代码在浏览器中运行,并输出 DOM 元素。同时,Vue.js 还可以在 Node.js 环境中运行,它可以将同样的组件渲染为字符串并发送给浏览器。这实际上描述了 Vue.js 的两种渲染方式,即…

【云原生】什么是 Kubernetes ?

什么是 Kubernetes ? Kubernetes 是一个开源容器编排平台,管理着一系列的 主机 或者 服务器,它们被称作是 节点(Node)。 每一个节点运行了若干个相互独立的 Pod。 Pod 是 Kubernetes 中可以部署的 最小执行单元&#x…

电脑技巧:U盘运用小技巧,提升U盘运用寿命

目录 1、注意清洁,防止污染 2、别随意插拔 3、文件多时分段写入 4、U盘传输数据中切记拔掉U盘 5、建议不要长期将U盘插在电脑上 6、杜绝别频繁将U盘格式化 7、U盘中毒怎么办 U盘是大家日常办公经常用得到的便携式文件储存工具,因为其小巧便携、方…

5.3每日一题(不确定正负号的级数敛散性:和一个正项级数比较判定)

比较判别法和比较判别法的极限形式是对正项级数而言的&#xff0c;若一个级数和p级数比较&#xff0c;结果>0&#xff0c;则同敛散&#xff1b;若结果<0&#xff0c;则结果乘以-1 结果又同敛散了&#xff1b;所以只要比值不等于0&#xff0c;则同敛散&#xff1b; 所以当…

鸿蒙(HarmonyOS)应用开发——生命周期、渲染控制、状态管理装饰器

生命周期 任何程序都是有一定的生命周期的。生命周期是记录从产生到销毁的过程&#xff1b;如果熟悉前端vue.js的话&#xff0c;就可以很好的理解生命周期。 自定义组件生命周期 ArkTS中&#xff0c;自定义组件提供了两个生命周期函数&#xff1a;aboutToAppear() 和aboutTo…

代码随想录算法训练营第四十七天|198. 打家劫舍、213. 打家劫舍II、337. 打家劫舍III

LeetCode 198. 打家劫舍 题目链接&#xff1a;198. 打家劫舍 - 力扣&#xff08;LeetCode&#xff09; 第一次打家劫舍&#xff0c;来个简单一些的&#xff0c;无非就是偷了当前这家偷不了下一家&#xff0c;因此dp[n]代表&#xff0c;偷前n家的时候所能偷到的最高金额&#x…

记一次RocketMQ线上broker内存持续升高问题排查

RocketMQ 版本 5.1.0 jdk版本 1.8 JVM启动参数 -Xms46g -Xmx46g -XX:MetaspaceSize1259m -XX:MaxMetaspaceSize2517m -XX:UseG1GC -XX:G1HeapRegionSize16m -XX:G1ReservePercent25 -XX:InitiatingHeapOccupancyPercent30 -XX:SoftRefLRUPolicyMSPerMB0 -verbose:gc -Xlog…

【Docker】Docker与Kubernetes:区别与优势对比

前言 Docker 是一个开源的应用容器引擎&#xff0c;让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux或Windows操作系统的机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。   kubernetes&#xff0c;简称K8s&a…

Nacos身份绕过漏洞复现(QVD-2023-6271)

Nacos身份绕过漏洞复现&#xff08;QVD-2023-6271&#xff09; 环境配置 该漏洞主要用了win10_JAVA的环境&#xff0c;参考网上已有的复现文章&#xff0c;使用jdk-11.0.2_windows-x64_bin.exe 由于2.2.0之后的nacos已将本漏洞修复&#xff0c;所以本次复现使用2.2.0的包 下…

cephadm部署ceph quincy版本

环境说明 IP主机名角色 存储设备 192.168.2.100 master100 mon,mgr,osd,mds,rgw 大于5G的空设备192.168.2.101node101mon,mgr,osd,mds,rgw大于5G的空设备192.168.2.102node102mon,mgr,osd,mds,rgw大于5G的空设备 关闭防火墙 关闭并且禁用selinux 配置主机名/etc/hosts …

深度学习之图像分类(十四)CAT: Cross Attention in Vision Transformer详解

IPSA和CPSA的处理流程、维度变换细节 FLOPs的计算方法、以及flops和划分的patch数目以及patch的维度计算关系 IPSA如何进行local attention、CPSA如何进行globe attention CAT的代码详细注释---需要学习完Transformer TNT、swin transformer、crossViT CAT: Cross Atten…

2023年【道路运输企业安全生产管理人员】最新解析及道路运输企业安全生产管理人员复审考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 道路运输企业安全生产管理人员最新解析是安全生产模拟考试一点通总题库中生成的一套道路运输企业安全生产管理人员复审考试&#xff0c;安全生产模拟考试一点通上道路运输企业安全生产管理人员作业手机同步练习。2023…

【Web】攻防世界 难度3 刷题记录(1)

目录 ①lottery ②ics-05 ③mfw ④simple_js ⑤fakebook 感觉自己对一些综合题的熟练度不太够&#xff0c;专项训练一下 ①lottery 抽奖赚钱&#xff0c;钱够9990000可买flag 随便输一串数字抓包&#xff0c;然后查看到一个post请求&#xff0c;api.php,题目里面有附件…

armbian折腾之docker搭建chatgptweb指导(无需魔法)

文章目录 前言面板/docker的安装获取中转Key创建docker容器chatgpt-next-web部署[推荐]chatgpt-Web部署 推荐学习openai-hk官方的部署指导 前言 好久都没有折腾armbian&#xff0c;导致吃了很长时间的灰&#xff0c;今天偶然看到B站UP主JeeJK007的搭建视频&#xff0c;便想着能…

电脑技巧:电脑常见蓝屏、上不了网等故障及解决办法

目录 一、电脑蓝屏 常见原因1: 病毒木马 常见原因2: 安装了不兼容的软件 二、电脑不能上网 常见原因1: 新装系统无驱动 常见原因2: DNS服务器异常 常见原因3: 硬件问题 三、电脑没声音 常见原因1: 未安装驱动 常见原因2: 硬件故障 四、电脑屏幕不显示 常见原因1: 显…

【Mybatis】基础增删改查

一.创建SpringBoot项目 创建新项目需要添加的依赖 当然如果是以前的项目也可以直接在pom.xml文件中添加依赖: MySQL Driver依赖 <dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><scope>runtime</…