haproxy的工具及其算法

news2025/1/11 2:59:25

一、socat 工具

dnf install socat -y

#查看帮助文档

echo "help" | socat stdio /var/lib/haproxy/stats

#查看参数

echo "show info" | socat stdio /var/lib/haproxy/stats

#查看服务状态

echo "show servers state" | socat stdio /var/lib/haproxy/stat

#查看权重

echo "get weight webcluster/web1" | socat stdio /var/lib/haproxy/stats

#更改权重

echo "set weight webcluster/web1 2" | socat stdio /var/lib/haproxy/stats

基本实验:

环境准备:

需要三台虚拟机:

rhel9克隆:haproxy(172.25.254.100)、webserver1(172.25.254.10)、webserver2(172.25.254.20)

见上个文档,可在上个文档实验的基础上进行操作

haproxy是什么?以及haproxy基础实验-CSDN博客

实验步骤:

[root@haproxy ~]# vim /etc/haproxy/haproxy.cfg 
[root@haproxy ~]# ll /var/lib/haproxy/stats 
srwxr-xr-x 1 root root 0 Aug  9 11:11 /var/lib/haproxy/stats
[root@haproxy ~]# 
[root@haproxy ~]# dnf install socat -y
#查看帮助文档
[root@haproxy ~]# echo "help" | socat stdio /var/lib/haproxy/stats 
#查看信息
[root@haproxy ~]# echo "show info" | socat stdio /var/lib/haproxy/stats
#查看服务状态
[root@haproxy ~]# echo "show servers state" | socat stdio /var/lib/haproxy/stats 
#查看权重
[root@haproxy ~]# echo "get weight webcluster/web1" | socat stdio /var/lib/haproxy/stats 
2 (initial 2)

#更改权重
[root@haproxy ~]# echo "set weight webcluster/web1 1" | socat stdio /var/lib/haproxy/stats 

#禁止web1
[root@haproxy ~]# echo "disable server webcluster/web1" | socat stdio /var/lib/haproxy/stats 

#启动web1
[root@haproxy ~]# echo "enable server webcluster/web1" | socat stdio /var/lib/haproxy/stats 

#多进程实验
[root@haproxy ~]# vim /etc/haproxy/haproxy.cfg 
[root@haproxy ~]# systemctl restart haproxy.service 
[root@haproxy ~]# ll /var/lib/haproxy/
total 0
srw------- 1 root root 0 Aug  9 11:51 stats
srw------- 1 root root 0 Aug  9 11:56 stats1
srw------- 1 root root 0 Aug  9 11:56 stats2
[root@haproxy ~]# echo "show info" | socat stdio /var/lib/haproxy/stats 		#因为没有使用stats,所以查不到信息
2024/08/09 12:00:04 socat[2544] E connect(5, AF=1 "/var/lib/haproxy/stats", 24): Connection refused
[root@haproxy ~]# echo "show info" | socat stdio /var/lib/haproxy/stats1 

测试: 

#这是权重为2的轮询
[root@webserver1 ~]# for i in {1..10}
> do
> curl 172.25.254.100
> done
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
webserver1 - 172.25.254.10
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
webserver1 - 172.25.254.10
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
#这是修改权重后,权重为1的轮询
[root@webserver1 ~]# for i in {1..10}; do curl 172.25.254.100; done
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
#这是禁用web1的轮询
[root@webserver1 ~]# for i in {1..10}; do curl 172.25.254.100; done
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
webserver2 - 172.25.254.20
#这是启动web1的轮询
[root@webserver1 ~]# for i in {1..10}; do curl 172.25.254.100; done
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10
webserver2 - 172.25.254.20
webserver1 - 172.25.254.10

 #多进程实验

er

二、haproxy算法

1. 静态
static-rr            cp/http                                 #不管后端
first                  tcp/http


2. 动态
roundrobin        tcp/http
leastconn          tcp/http                               #谁链接少,权重高,就给谁
random             tcp/http


3. 以下静态和动态取决于 hash_type 是否 consistent
source              tcp/http
Uri                     http                                      #访问地址内容进行hash
url_ param        http                                       #对动作请求进行hash
hdr                    http                                       #对报文头进行hash

2.1 静态算法

static-rr

支持权重,不支持调整权重

步骤:
[root@haproxy ~]# vim /etc/haproxy/haproxy.cfg 
[root@haproxy ~]# systemctl restart haproxy.service 

 

测试:

前后对比 

first

2.2 动态算法

roundrobin

步骤:
[ root@haproxy ~]# vim /etc/haproxy/haproxy.cfg 
[ root@haproxy ~]# systemctl restart haproxy.service
[ root@haproxy ~]# echo "get weight webcluster/web1" | socat stdio /var/lib/haproxy/stats
[ root@haproxy ~]# echo "set weight webcluster/web1 1" | socat stdio /var/lib/haproxy/stats
[ root@haproxy ~]# echo "get weight webcluster/web1" | socat stdio /var/lib/haproxy/stats

测试:

set前后对比

leastconn

2.3 其他算法

source

(balance source)静态

步骤:

map-base 取模法

通过取模的结果访问主机(当权重都为1时,几台机子取模就取几)(当其中一台机器的权重变化后,导致会话丢失,解决该方法使用hash一致性)

hash一致性

hash算法(动态)

步骤:
[ root@haproxy ~]# vim /etc/haproxy/haproxy.cfg
[ root@haproxy ~]# systemctl restart haproxy.service
[ root@haproxy ~]# echo "set weight webcluster/web1 1" | socat stdio /var/1ib/haproxy/stats
Backend is using a static LB algorithm and only accepts weights ' 0% ' and ' 100% '

#前后对比
[ root@haproxy ~]# vim /etc/haproxy/haproxy.cfg
[ root@haproxy ~]# systemctl restart haproxy.service
[ root@haproxy ~]# echo "set weight webcluster/web1 1" | socat stdio /var/Lib/haproxy/stats

uri

默认是静态算法

?前,向服务器传递的指令

?后,指令的目标,字段

#后面,为片段

uri取模法

uri不变,访问的地址也就不变,不会根据轮询效果来

步骤:
[ root@haproxy ~]# vim /etc/haproxy/haproxy.cfg
[ root@haproxy ~]# systemctl restart haproxy.service

[ root@webserver1 ~]# echo 172.25.254.10 - index1.html > /usr/share/nginx/html/index1.html
[ root@webserver1 ~]# echo 172.25.254.10 - index2.html > /usr/share/nginx/html/index2.html
[ root@webserver1 ~]# echo 172.25.254.10 - index3.html > /usr/share/nginx/html/index3.html
[ root@webserver2 ~]# echo 172.25.254.20 - index1.html > /usr/share/nginx/html/index1.html
[ root@webserver2 ~]# echo 172.25.254.20 - index2.html > /usr/share/nginx/html/index2.html
[ root@webserver2 ~]# echo 172.25.254.20 - index3.html > /usr/share/nginx/html/index3.html
测试:

两台web设置一个index1和设置三个的前后对比:

url_param一致性

测试结果

不使用数字,会导致(与取模的数字冲突)出问题

链接问题,会断开变化主机IP

同一个name,就返回同一个IP

hdr

步骤:

结果: 

三、状态页测试实验

 

 

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

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

相关文章

【Vue3】嵌套路由

【Vue3】嵌套路由 背景简介开发环境开发步骤及源码 背景 随着年龄的增长,很多曾经烂熟于心的技术原理已被岁月摩擦得愈发模糊起来,技术出身的人总是很难放下一些执念,遂将这些知识整理成文,以纪念曾经努力学习奋斗的日子。本文内…

智匠MindCraft AI 1.2.6版本更新啦!!

智匠MindCraft AI​​​​​​​迎来1.2.6版本更新,本次更新四大内容: 1、网页代码及python代码渲染优化。更稳定的代码渲染功能,您可以在智匠AI中,实现炫酷的网页效果,或者用python制作图表和游戏。 2、语音实验室增…

Linux 配置定时任务

Linux定时任务,通常被称为Cron Jobs,在系统管理和运维自动化领域中扮演着至关重要的角色,并且在日常的服务器维护活动中也展现出了广泛而深远的应用价值。这种强大的工具允许用户按照预定的时间周期自动执行各种任务,如数据备份、…

springboot中的工厂模式

说到工厂模式,先说说工厂模式是什么,有什么优点 平常我们在工作开发过程中,往往因为工期问题导致整体功能设计考虑的不够周到,导致后期迭代时发现需要原有功能流程基础上追加新功能时,需要耗费更多的成本,…

【HarmonyOS NEXT星河版开发学习】小型测试案例16-小米官网轮播图部分

个人主页→VON 收录专栏→鸿蒙开发小型案例总结​​​​​ 基础语法部分会发布于github 和 gitee上面(暂未发布) 前言 鸿蒙开发中的Swiper组件应用十分的广泛,像小米、淘宝、京东...众多网友都采用了轮播图的效果。不仅更加的美观&#xff0c…

AutoTiny电脑自动化操作

AutoTiny 可以自动化电脑上的一些操作,比如帮你重复鼠标点击操作(我猜可以当作外挂刷怪,可惜已经过了喜欢刷怪的年纪了)

Linux学习之路 -- 进程 -- 进程间通信 -- 管道通信

本文主要介绍进程通信中的管道通信。 前面我们学习进程的过程中,我们知道,进程是具有独立性的。这也就导致了进程不能够直接地把数据进行传递。为了实现进程之间地通信,我们就需要通过另外地方式来实现进程之间数据地传递。 1.进程通信的目…

训练 Transfomer 模型的内存消耗计算

目录 model 内存gradients 内存activates 内存 经典图打底: 训练深度模型的内存消耗主要有以下几个部分: 存储模型可训练参数存储梯度存储反向传播中间变量,例如: L ( Y − Y ^ ) 2 Y ^ X T W ∂ L ∂ W − 2 ( Y − Y ^ ) …

Transformer架构;Encoder-Decoder;Padding Mask;Sequence Mask;

目录 Transformer架构 Transformer架构的主要组成部分: 简单举例说明输入和输出: Encoder-Decoder 编码器/解码器组成 6、位置前馈网络(Position-wise Feed-Forward Networks) 7、残差连接和层归一化 10、掩码Mask 10.1 Padding Mask 10.2 Sequence Mask 为什么…

Gradio 复杂布局的实现

Gradio Interface 和 ChatInterface 布局都相对固定,只能通过参数添加组件,如果想要自定义页面布局,就需要更高级的布局方式 Block 。Gradio 中可以通过行和列进行布局,可以互相嵌套。我们先看一官方的例子: import g…

Vue Mixins 深度解析含面试常问题

Vue Mixins 深度解析含面试常问题 文章目录 Vue Mixins 深度解析含面试常问题一、Mixin 是什么二、Vue中如何使用1. 创建Mixin2. 使用Mixin3. 合并策略4. 全局Mixin5. 使用场景 三、包含哪些属性或方法API四、扩展与高级技巧1. 命名冲突2. 全局 vs 局部3. 合并策略深入4. 使用高…

商品期权会爆仓吗?

商品期权交易中存在爆仓的情况。一个期权的价格与其基础资产的波动性密切相关。在波动性高的情况下,尽管收益可能更高,但投资者也需要面对更大的价格波动风险,商品期权有买方和卖方,买方无爆仓风险,卖方是保证金交易有…

Hadoop大数据集群搭建

一、虚拟机配置网络 1、配置文件 进入“/etc/sysconfig/network-scripts”目录,查看当前目录下的“ifcfg-ens33”文件 对“ens33”文件进行配置 2、重启网络 systemctl restart network 3、测试网络 Ping www.baidu.com 4、设置虚拟机主机名称 5、绑定主机名和…

【android 9】【input】【11.发送普通motion事件1——touch设备的加载——MultiTouchInputMapper】

系列文章目录 可跳转到下面链接查看下表所有内容https://blog.csdn.net/handsomethefirst/article/details/138226266?spm1001.2014.3001.5501文章浏览阅读2次。系列文章大全https://blog.csdn.net/handsomethefirst/article/details/138226266?spm1001.2014.3001.5501 目录 …

传知代码-CENet及多模态情感计算实战(论文复现)

代码以及视频讲解 本文所涉及所有资源均在传知代码平台可获取 一、概述 本文对 “Cross-Modal Enhancement Network for Multimodal Sentiment Analysis” 论文进行讲解和手把手复现教学,解决当下热门的多模态情感计算问题,并展示在MOSI和MOSEI两个数…

labview经验分享1-任意16进制字符类型匹配

系列文章目录 1、任意16进制字符类型匹配 文章目录 系列文章目录问题导入实现任意16进制字符类型匹配在这里插入图片描述 总结 问题导入 labveiw的字符串匹配,使用的是正则表达式,可以让我们很方便的对字符串进行字符处理操作。 但是某些情况下&#…

WEB渗透Bypass篇-常规操作

绕过lsa-protection https://github.com/RedCursorSecurityConsulting/PPLKillerLinux绕过disable_function LD_PRELOAD linux环境 putenv()、mail()可用 https://github.com/yangyangwithgnu/bypass_disablefunc_via_LD_PRELOAD http://192.168.0.107/bypass_disablefunc.p…

一篇文章教你搭建一个高深莫测的SQL优化器

❓在数据库操作中,SQL优化一直是一个让人头疼的问题。今天,我将教你一种无需编写任何代码,只需要两个组件,便能轻松搭建一个高深莫测的SQL优化器的方法。通过这个方法,它可以将巨慢无比的SQL,把速度优化到极…

重启人生计划-浮舟沧海

🥳🥳🥳 茫茫人海千千万万,感谢这一刻你看到了我的文章,感谢观赏,大家好呀,我是最爱吃鱼罐头,大家可以叫鱼罐头呦~🥳🥳🥳 如果你觉得这个【重启人生…

VIM复合命令

VIM提供了很多 复合命令,可以把两个动作合并为一次按键。极大提高了编辑效率。以下是一些具体的例子: 复合命令等效的长命令说明Cc$删除光标到行尾scl删除光标位置的字符S^C删除整行I^i光标移动到行首A$a光标移动到行尾oA 回车光标下方开启一行Oko光标…