• 常见服务知识点罗列--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
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    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保持会话
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    动态调度算法:

    roundrobin:
    #基于权重的轮询动态调度算法,支持权重的运行时调整,不等于lvs的rr,支持慢启动即新加的服务器会逐渐增加转发数,每个后端backend中最多支持4095个server,此为默认调度算法,server 权重设置 weight
    leastconn:
    #加权的最少连接的动态,支持权重的运行时调整和慢启动,即当前后端服务器连接最少的优先调度,比较适合长连接的场景使用,比如MySQL等场景。
    
    • 1
    • 2
    • 3
    • 4

    hash:

    map-based:取模法
    #基于服务器权重的hash数组取模,该hash是静态的即不支持在线调整权重,不支持慢启动,其对后端服务器调度均衡,缺点是当服务器的总权重发生变化时,即有服务器上线或下线,都会因权重发生变化而导致调度结果整体改变,hash(o)mod n 。
    consistent:一致性hash
    #该hash是动态的,支持在线调整权重,支持慢启动,优点在于当服务器的总权重发生变化时,对调度结果影响是局部的,不会引起大的变动。
    
    • 1
    • 2
    • 3
    • 4

    二、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
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    3、双主配置

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

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

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

  • 相关阅读:
    fastjson反序列化漏洞(CVE-2017-18349)
    vue计算属性computed && 侦听器watch
    Kotlin 开发Android app(八):Kotlin类对象class
    GBase 8c V3.0.0数据类型——文本检索调试函数
    简单的谈谈VPN是什么、类型、使用场景以及工作原理?
    Java项目:JSP会议-会议室管理系统
    django学习之路(1)-初识 Django
    Mybatis中拦截器的使用场景和技巧
    CF1004F Sonya and Bitwise OR(线段树平衡复杂度+or 前缀性质)
    深入了解“注意力”和“变形金刚” -第1部分
  • 原文地址:https://blog.csdn.net/weixin_44515412/article/details/125597110