HAproxy-7层负载均衡集群根据不同服务请求分配服务器

搭建HAproxy----7层负载均衡集群的补充

https://blog.csdn.net/qq_73990369/article/details/142500451?spm=1001.2014.3001.5501

一、再准备两台虚拟机进行测试

192.168.229.15/24 ----php1

192.168.229.16/24 ----php2

1、PHP1 & php2(192.168.229.15/24 ,192.168.229.16/24 )

复制代码
yum install httpd php -y

2、分别创建测试页面 index.php ,开启服务

复制代码
vim /var/www/html/index.php

1.php1

php1111111

2.php2

php222222

3、启动httpd

复制代码
systemctl start httpd

二、修改配置文件(192.168.229.12)

复制代码
vim /etc/haproxy/haproxy.cfg

global
		log 127.0.0.1 local3 info	   #日志服务器
		maxconn 4096				   #最大连接数
		uid nobody					   #用户身份
		gid nobody					   #组身份
		daemon						   #守护进程方式后台运行
		nbproc 1						   #工作进程数量
		
####### ###########默认设置 ###################
#####这些参数是配置 frontend,backend,listen 组的 ###########		
	defaults                    #这些参数可以被利用配置到frontend,backend,listen组件   
		log		   global
		mode	   http	    #工作模式 http ,tcp 是 4 层,http是 7 层	
		maxconn 2048		#最大连接数
		retries 	3			    #3 次连接失败就认为服务器不可用
		option	redispatch	#如果 cookie 写入了 serverId 而客户端不会刷新 cookie,当serverId 对应的服务器挂掉后,强制定向到其他健康的服务器
		stats	uri  /haproxy	#使用浏览器访问 http://192.168.229.12/haproxy,可以看到服务器状态
		stats auth           wing:123     #用户认证,客户端使用elinks浏览器的时候不生效
		contimeout	5000          #连接超时时间,单位毫秒ms
		clitimeout	    50000        #客户端超时
		srvtimeout	    50000        #服务器超时
		
		
	frontend http-in
		bind 0.0.0.0:80                           #监听端口
		mode http
		log global
		option httplog			                 #日志类别 http 日志格式
		option httpclose		                 #打开支持主动关闭功能,每次请求完毕后主动关闭http通道	,ha-proxy不支持keep-alive,只能模拟这种模式的实现	
	    acl php url_reg  -i  \.php$			 #acl <ACL名字>  <类型>  <大小写>  <规则>
	    acl html url_reg  -i  \.html$		  	 #use_backend  <服务器组>  if  <ACL名字>
	    use_backend php-server if  php
	    use_backend html-server if  html
	    default_backend html-server		 #默认使用的服务器组
	

	backend php-server
		mode http
		balance roundrobin			            #负载均衡的方式
		option httpchk GET /index.php		#健康检查
		cookie SERVERID insert indirect nocache	#客户端的 cookie 信息,允许插入serverid到cookie中,此处cookie号不同
		server php-A 192.168.229.15:80 weight 1 cookie 1 check inter 2000 rise 2 fall 5
		server php-B 192.168.229.16:80 weight 1 cookie 2 check inter 2000 rise 2 fall 5
		#cookie 1 标识 serverid 为 1
		#check inter 2000          检测心跳频率
		#rise 2     2 次正确认为服务器可用
		#fall 5      5 次失败认为服务器不可用
	
	backend html-server
		mode http
		balance roundrobin
		option httpchk GET /index.html
		cookie SERVERID insert indirect nocache
		server html-A 192.168.229.13:80 weight 1 cookie 3 check inter 2000 rise 2 fall 5
		server html-B 192.168.229.14:80 weight 1 cookie 4 check inter 2000 rise 2 fall 5

重新启动HAproxy

复制代码
systemctl restart haproxy.service

配置域名解析

复制代码
vim /etc/hosts

192.168.229.15 php1
192.168.229.16 php2

在客户端(Client)访问 HAproxy 测试

复制代码
elinks --dump http://haproxy/index.html
elinks --dump http://192.168.229.12/index.php
相关推荐
繢鴻16 分钟前
Nginx 配置顺序错误
运维·nginx·阿里云·持续部署
木雷坞22 分钟前
2026年4月实测:K8s containerd 镜像拉取全方案汇总
运维·容器·kubernetes
℡終嚸♂68024 分钟前
Vite 开发服务器文件读取 Writeup
运维·服务器·状态模式
开开心心_Every37 分钟前
动图制作工具,拆分转视频动态照离线免费
运维·前端·人工智能·edge·pdf·散列表·启发式算法
薛定猫AI1 小时前
【技术干货】OpenAI Codex 重大更新:从代码补全工具到全流程智能开发平台
运维·人工智能
曦云沐1 小时前
Linux 下极简安装 Conda(Miniconda / Anaconda),5 分钟搞定环境配置
linux·运维·conda
key_3_feng1 小时前
基于OpenClaw的Alibaba Cloud Linux 3自动化部署YashanDB深度方案
linux·运维·自动化·yashandb
zzzsde1 小时前
【Linux】进程信号(2)保存信号与信号处理
linux·运维·服务器·算法
代码飞天1 小时前
CTF之文件上传——你知道我在你的服务器上放了什么吗
运维·服务器
wsdswzj2 小时前
web与web服务器基础安全
服务器·前端·安全