HAPRoxy(一):HAProxy基本配置、调度算法与tcp、http、heath模式配置示例
一、HAProxy安装
1.HAProxy简单介绍
HAProxy虽然名字前有HA,但它并不是一款高可用软件,而是一款用于实现负载均衡的软件,可实现四层与七层的负载均衡。
2.yum安装HAProxy
HAProxy已经包含在yum的base中,版本为1.15,可以直接yum安装
~]# yum install -y haproxy
HAProxy的配置文件路径为:/etc/haproxy/haproxy.cfg
主程序路径为:/usr/sbin/haproxy
3.HAProxy配置
HAProxy配置段分为两大部分:
1.全局配置段,在配置文件中的标识为global,主要功能有如下:
a.在global中可以对HAProxy的进程及安全相关参数进行配置
b.性能调整
c.Debug
2.代理配置段,在配置文件中的标识为proxyies,它还分为如下小段:
a.default:为frontend,listen,backend提供默认配置
b.frontend:前端主机配置,可类比于Nginx的server { }
c.listen:将前端和后端整合在一起配置,同时拥有前端和后端。
HAProxy简单配置示例
HAProxy默认配置如下:
global
local2.* /var/log/haproxy.log #HAProxy日志文件依赖于rsyslog,这里的log配置与rsyslog相关
chroot /var/lib/haproxy
pidfile /var/run/haproxy.pid #运行的pid文件路径
maxconn 4000 #设置最大可支持的并发连接数
user haproxy
group haproxy
daemon
# turn on stats unix socket
stats socket /var/lib/haproxy/stats defaults
mode http #设置HAProxy默认的工作模式,有tcp,http,health三种
log global
option httplog
option dontlognull
option http-server-close
option forwardfor except 127.0.0.0/
option redispatch
retries
timeout http-request 10s
timeout queue 1m
timeout connect 10s
timeout client 1m
timeout server 1m
timeout http-keep-alive 10s
timeout check 10s
maxconn 3000 #最大连接数 frontend main *:
acl url_static path_beg -i /static /images /javascript /styl
esheets
acl url_static path_end -i .jpg .gif .png .css .js use_backend static if url_static
default_backend app backend static
balance roundrobin
server static 127.0.0.1: check backend app
balance roundrobin
server app1 127.0.0.1: check
server app2 127.0.0.1: check
server app3 127.0.0.1: check
server app4 127.0.0.1: check
简单的代理段配置:
frontend web #自定义前端服务器名,这里为web
bind *:80 #设置监听的端口与IP
default_backend websrvs #配置默认调用的名为websrvs的后端服务器组 backend websrvs #定义后端服务器名
balance roundrobin #配置算法类型
server srv1 172.16.100.6: check #配置主机参数,check为健康状态检测
server srv2 172.16.100.7: check
说到HAProxy的调度算法,这里简单介绍一下:
HAProxy调度算法:
HAProxy在balance中定义
格式为 balance <algorithm> [ <arguments> ]
1.roundrobin 根据服务器权重轮询的算法,可以自定义权重,它支持慢启动,并能在运行时修改权重,所以是一种动态算法。最多支持4095台后端主机。
2.static-rr 与roundrobin类似,static-rr也是一种轮询算法,但它是静态的,对后端主机数量无限制。
3.leastconn 最小连接数算法,一种可以根据后端主机连接数情况进行调度的动态算法,支持慢启动和运行时调整,可将新的请求调度至连接数较少的后端主机。与LVS中lc算法类似。
4.first 根据服务器标识顺序选择服务器,当服务器承载的连接数达到maxconn的值后便将新情求调度至下一台服务器。此算法只在一些特殊场景下使用。
5.source 对请求的源IP地址进行hash处理,根据hash运算处理结果调度至后端服务器。可使固定IP的请求始终调度至统一服务器。
6.uri 根据请求的uri进行hash处理并调度之后端主机。
7.url_param 将URL的参数进行判断并进行hash计算,参数可以自定义,任何的URL参数都可以。
8.hdr <name>根据请求中的HTTP报文首部的值进行hash计算并调度。name可以是GET、USERAGENT等首部名。
HAProxy可以选择普通hash算法也可以选择一致性hash算法。可用参数hash_type配置。
4.HAProxy中四层负载与七层负载的简单演示
mode参数可设置HAProxy工作在四层还是七层,在HAProxy中mode有三种工作模式:
1.tcp:基于layer4实现代理;可代理mysql, pgsql, ssh, ssl等协议;
2.http:仅当代理的协议为http时使用;
3.health:工作为健康状态检查的响应模式,当连接请求到达时回应“OK”后即断开连接;
1.tcp模式下负载均衡简单示例
IP分配如下:
HAProxy主机:192.168.29.101
后端主机1:192.168.29.102 后端主机2:192.168.29.103
客户端主机:192.168.29.104
将默认配置/etc/haproxy/haproxy.cfg中默认的frontend、backend注释掉,重新添加如下配置:
listen sshd
mode tcp
bind *:
balance leastconn
server sshd1 192.168.29.102: check
server sshd2 192.168.29.103: check
启动HAProxysy
~]# stemctl start haproxy
注:所有服务器都关闭了firewall和selinux
用客户端做测试,看ssh请求是否由HAProxy负载均衡至后端,如下图:

2.http模式下负载均衡简单示例
a.在两台后端服务器上yum安装Nginx服务
b.设置默认主页index.html,将主页内容设置分别设置为B1和B2。

c.开启Nginx服务,检查80端口是否在监听状态。
d.配置HAProxy服务,注释掉上例中的listen配置,添加配置文件如下(本示例的配置也可在listen中配置,这里为不与上例重复,分别在frontend和backend中配置):
frontend myweb
bind *:
default_backend app backend app
balance roundrobin
server app1 192.168.29.102: check
server app2 192.168.29.103: check
重启HAProxy后在客户端访问HAProxy主机并刷新,可看到内容不断切换,说明http请求被负载均衡代理至后端主机,调度算法为roundrobin:

5.HAProxy的cookie配置基础
1.什么是cookie?
由于HTTP是一种无状态的协议,服务器单从网络连接上无从知道客户身份。怎么办呢?就给客户端们颁发一个通行证吧,每人一个,无论谁访问都必须携带自己通行证。这样服务器就能从通行证上确认客户身份了。这就是Cookie的工作原理。Cookie实际上是一小段的文本信息。客户端请求服务器,如果服务器需要记录该用户状态,就使用response向客户端浏览器颁发一个Cookie。客户端浏览器会把Cookie保存起来。当浏览器再请求该网站时,浏览器把请求的网址连同该Cookie一同提交给服务器。服务器检查该Cookie,以此来辨认用户状态。服务器还可以根据需要修改Cookie的内容。
2.为什么需要cookie?
举一个大家都在举的例子:客户端第一次访问某购物网站时,集群中负载均衡会根据设置好的算法分配至后端某服务器A,若负载均衡开启了cookie机制,则负载均衡会给客户端一个身份标识,以后只要是该客户访问网站,都会将请求发送至后端服务器A。这就绑定了用户和后端服务器。与ip_hash不同的是,这种方式的绑定更精细,设置更灵活,就算用户换IP也不会影响绑定。
3.cookie简单配置
基本格式:cookie <name> [ rewrite | insert | prefix ] [ indirect ] [ nocache ] [ postonly ] [ preserve ] [ httponly ] [ secure ] [ domain <domain> ]* [ maxidle <idle> ] [ maxlife <life> ]
<name>:is the name of the cookie which will be monitored, modified or inserted in order to bring persistence.
在上例配置中添加cookie配置,使客户端绑定至后端某台主机
frontend myweb
bind *:
default_backend app
stats enable #开启HAProxy的状态页功能
stats auth admin:asd12345 #设置状态页登入密码 backend app
balance leastconn
cookie server insert nocache #在nocache中插入名为server的cookie键
server app1 192.168.29.102: check cookie svr1 #server app1的键值为svr1
server app2 192.168.29.103: check cookie svr2 #server app1的键值为svr2
重启HAProxy后无论怎么刷新都不会切换内容了。查看网页的cookie内容:

说明绑定在了svr1上了。
HAPRoxy(一):HAProxy基本配置、调度算法与tcp、http、heath模式配置示例的更多相关文章
- haproxy+keepalived主备与双主模式配置
Haproxy+Keepalived主备模式 主备节点设置 主备节点上各安装配置haproxy,配置内容且要相同 global log 127.0.0.1 local2 chroot /var/lib ...
- keepalived高可用haproxy负载均衡varnish缓存wordpress的动静分离(第一次配置成功)
haproxy和nginx都可以作为七层和四层反代服务器对外提供服务,此文通过haproxy和keealived配置varnish搭建wordpress的动静分离站点 一.实验环境 五台虚拟机: ha ...
- 安装haproxy和haproxy命令
HaProxy系列文章:http://www.cnblogs.com/f-ck-need-u/p/7576137.html 1.安装haproxy CentOS自带了haproxy,但可能版本比较老. ...
- socat管理haproxy以及haproxy调优
Unix套接字命令(Unix Socket commands) socat是一个多功能的网络工具,名字来由是“Socket CAT”,可以看作是netcat的N倍加强版,socat的官方网站:http ...
- [转帖]关于网络编程中MTU、TCP、UDP优化配置的一些总结
关于网络编程中MTU.TCP.UDP优化配置的一些总结 https://www.cnblogs.com/maowang1991/archive/2013/04/15/3022955.html 感谢原作 ...
- nginx启用TCP反向代理日志配置
Nginx使用TCP反向代理日志配置不同于http 修改nginx配置文档/usr/local/nginx/conf/nginx.conf 设置日志格式 stream { log_format pro ...
- 云计算介绍、TCP/IP协议及配置
云计算介绍.TCP/IP协议及配置 1案例1:配置计算机名及工作组 1.1问题 本例要求为修改计算机名并加入工 ...
- RabbitMQ学习之集群镜像模式配置
1.增加负载均衡器 关于负载均衡器,商业的比如F5的BIG-IP,Radware的AppDirector,是硬件架构的产品,可以实现很高的处理能力.但这些产品昂贵的价格会让人止步,所以我们还有软件负载 ...
- LVS+keepalived DR模式配置高可用负载均衡集群
实验环境 LVS-Master 10.0.100.201 VIP:10.0.100.203 LVS-Slave 10.0.100.204 WEB1-Tomcat 10.0.2.29 gat ...
随机推荐
- Python Day 2
阅读目录: 内容回顾 编程语言介绍 python语言介绍 安装官方cpython解释器 --版本共存 运行python代码 --交互式:实时交互 --脚本式:运行py文件的三步骤 变量 ...
- C++ MFC棋牌类小游戏day2
反思了一下昨天的设计,觉得略有不足,我决定把棋盘做成单例模式.这样的话需要重新设计棋盘类,emmm,是新建棋盘类. Baord类 成员变量: Location coordinate;//棋子坐标 b ...
- vs.code调试node.js的C++扩展
其实也很简单 点击“Add Configration..”后,会在launch.json增加一个节点,稍调整两个位置 以上完了后,就能在cpp源码里加上自己的断点,执行debug调试我们的C++源代码 ...
- POJ3204 Ikki's Story I - Road Reconstruction
Ikki's Story I - Road Reconstruction Time Limit: 2000MS Memory Limit: 131072K Total Submissions: 7 ...
- Navicat for MYSQL 数据库手动同步方法
Navicat for MYSQL 数据库手动同步方法 数据库同步有两种类型,一是结构同步,一般是数据库表增删,或是表中字段的增删:二是数据同步,即是表里面的记录的增删. 现假设我要让本地数据 ...
- C++回调:利用Sink
Sink的本质是利用C++的封装.继承.多态的面向对象来实现,从实现角度来说,更优于函数指针回调: // cbBysink.cpp : Defines the entry point for the ...
- 安装stress模拟linux系统资源消耗
1.安装yum源:yum install epel-release -y 2.安装stress:yum install stress -y 3.使用样例:stress -c 1 -t 60 4.测试场 ...
- 另一个画风的GSS1 - Can you answer these queries I(猫树)
前言 其实我觉得你看猫锟的解释也看不懂(主要是还有一些不良心的讲解者不讲清楚,当然这里不是针对了qwq) 猫锟链接 Solution 考虑我们的线段树是个啥玩意? 每一层都是一堆区间叠在一起. 我们在 ...
- Java面试集合(三)
前言 大家好,给大家带来Java面试集合(三)的概述,希望你们喜欢 三 1.在Java中是否可以含有多个类? 答:可以含有多个类,但只有一个是public类,public类的类名与文件名必须一致. 2 ...
- Swift5 语言指南(十一) 结构和类
结构和类是通用的,灵活的结构,它们成为程序代码的构建块.您可以使用与定义常量,变量和函数相同的语法来定义属性和方法,以便为结构和类添加功能. 与其他编程语言不同,Swift不要求您为自定义结构和类创建 ...