global、defaults、
#主要功能:实现负载均衡
[root@k8s-ha1 ~]#vim /etc/haproxy/haproxy.cfg
listen k8s-6443
bind 192.168.150.188:6443
mode tcp
server k8s1 192.168.150.151:6443 check inter 3s fall 3 rise 5
server k8s1 192.168.150.152:6443 check inter 3s fall 3 rise 5
server k8s1 192.168.150.153:6443 check inter 3s fall 3 rise 5
静态调度算法:定义调度规则
static-rr:
#基于权重的轮询调度,不支持权重的运行时调整及后端服务器慢启动,其后端主机数量没有限制
first:
#根据服务器在列表中的位置,自上而下进行调度,但是其只会当第一台服务器的连接数达到上限,新请求才会分配给下一台服务,因此会忽略服务器的权重设置。
#取决于hash_type是否consistent:
#mode http #不支持tcp,会切换到tcp的roundrobin负载模式(source支持tcp/http)
#balance source/uri/url_param/hdr/rdp-cookie
#hash-type consistent
source:
#后续同一个源地址请求将被转发至同一个后端web服务器
#源地址hash,基于用户源地址hash并将请求转发到后端服务器,默认为静态即取模方式,但是可以通过hash-type支持的选项更改,后续同一个源地址请求将被转发至同一个后端web服务器,比较适用于session保持/缓存业务等场景。
uri:
#curl http://192.168.7.101/index.html或test.html
#基于对用户请求的uri做hash并将请求转发到后端指定服务器
url_param name: #基于参数name做hash
#http://www.magedu.com/foo/bar/index.php?k1=v1&k2=v2
#url_param = "k1=v1&k2=v2"
#对用户请求的url中的<params>部分中的参数name作hash计算,并由服务器总权重相除以后派发至某挑出的服务器;通常用于追踪用户,以确保来自同一个用户的请求始终发往同一个Backend Server
hdr(<name>):
#不同的浏览器被调度到不同的web服务器,hdr( Cookie、 User-Agent、host)
#针对用户每个http头部(header)请求中的指定信息做hash,此处由<name>指定的http首部将会被取出并做hash计算,然后由服务器总权重相除以后派发至某挑出的服务器,假如无有效的值,则会被轮询调度
rdp-cookie(<name>):
#对远程桌面的负载,使用cookie保持会话
动态调度算法:
roundrobin:
#基于权重的轮询动态调度算法,支持权重的运行时调整,不等于lvs的rr,支持慢启动即新加的服务器会逐渐增加转发数,每个后端backend中最多支持4095个server,此为默认调度算法,server 权重设置 weight
leastconn:
#加权的最少连接的动态,支持权重的运行时调整和慢启动,即当前后端服务器连接最少的优先调度,比较适合长连接的场景使用,比如MySQL等场景。
hash:
map-based:取模法
#基于服务器权重的hash数组取模,该hash是静态的即不支持在线调整权重,不支持慢启动,其对后端服务器调度均衡,缺点是当服务器的总权重发生变化时,即有服务器上线或下线,都会因权重发生变化而导致调度结果整体改变,hash(o)mod n 。
consistent:一致性hash
#该hash是动态的,支持在线调整权重,支持慢启动,优点在于当服务器的总权重发生变化时,对调度结果影响是局部的,不会引起大的变动。
C语言编写的路由软件,提供负载均衡和高可用;其中负载均衡框架是基于ipvs内核模块,提供第四层负载均衡;高可用基于vrrp协议
global_defs、vrrp_instance、virtual_server
#主要功能:提供vip(虚拟ip)
[root@k8s-ha1 ~]#vim /etc/keepalived/keepalived.conf
vrrp_instance VI_1 {
state MASTER
interface eth0
virtual_router_id 1
priority 100
virtual_ipaddress {
192.168.150.188 dev eth0 label eth0:1
192.168.150.189 dev eth0 label eth0:1
192.168.150.190 dev eth0 label eth0:1
如何实现主从:配置文件中设置priority和state,预防单机故障
如何实现双主:互为主从,提高资源利用率(推荐)
在keepalived当中需要负载均衡功能,可以在编译keepalived时打开IPVS模块来实现负载均衡的功能,也可以通过编译参数关闭。