常见服务知识点罗列--haproxy/keepalived

一、haproxy

1、haproxy配置的主要模块

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
2、调度算法

静态调度算法:定义调度规则

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是动态的,支持在线调整权重,支持慢启动,优点在于当服务器的总权重发生变化时,对调度结果影响是局部的,不会引起大的变动。

二、keepalived

1、简介:

C语言编写的路由软件,提供负载均衡和高可用;其中负载均衡框架是基于ipvs内核模块,提供第四层负载均衡;高可用基于vrrp协议

2、keepalived配置的主要模块

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
3、双主配置

如何实现主从:配置文件中设置priority和state,预防单机故障
如何实现双主:互为主从,提高资源利用率(推荐)

4、常见错误理解:Keepalived就是一款负载均衡软件

在keepalived当中需要负载均衡功能,可以在编译keepalived时打开IPVS模块来实现负载均衡的功能,也可以通过编译参数关闭。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值