saltstack实现keepalive高可用集群

1.创建推送目录并修改keepalived推送配置文件

[root@server1 salt]# mkdir keepalived
[root@server1 salt]# cd keepalived
[root@server1 keepalived]# mkdir files
[root@server1 keepalived]# cp /etc/keepalived/keepalived.conf ##添加配置文件
[root@server1 keepalived]# vim files/keepalived.conf 
[root@server1 keepalived]# cat files/keepalived.conf 
! Configuration File for keepalived

global_defs {
   notification_email {
  	root@localhost
   }
   notification_email_from keepalived@localhost
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id LVS_DEVEL
}

vrrp_instance VI_1 {
    state {{ STATE }}##角色
    interface eth0
    virtual_router_id {{ VRID }}##虚拟id
    priority {{ PRIORITY }}##优先级高的为master
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        172.25.32.100
    }
}



2.编辑推送文件

[root@server1 keepalived]# vim install.sls ##编辑推送文件
[root@server1 keepalived]# cat install.sls 
keepalived-install:
  pkg.installed:
    - pkgs:
      - keepalived

  file.managed:
    - name: /etc/keepalived/keepalived.conf
    - source: salt://keepalived/files/keepalived.conf
    - user: root
    - group: root
    - mode: 644
    - template: jinja
    - context:
        STATE: {{ pillar['state'] }}##STATE选择变量为state
        VRID: {{ pillar['vrid'] }}##虚拟ID选择变量为vrid
        PRIORITY: {{ pillar['priority'] }}##优先级选择变量为priority
  service.running:
    - name: keepalived
    - enable: true
    - reload: true
    - watch:
      - file: keepalived-install


3.编辑相应的pillar文件(变量文件)

[root@server1 keepalived]# vim /srv/pillar/web/vars.sls 
[root@server1 keepalived]# cat /srv/pillar/web/vars.sls 
{% if grains['fqdn'] == 'server2' %} 
webserver: httpd 
state: MASTER
ip: 172.25.32.2
vrid: 32
priority: 100
port: 80
{% elif grains['fqdn'] == 'server3' %} 
webserver: nginx 
state: BACKUP
vrid: 32
priority: 99
ip: 172.25.32.3
port: 80
{% endif %}

4.编辑顶层推送文件

[root@server1 keepalived]# cd ..
[root@server1 salt]# vim top.sls 
[root@server1 salt]# cat top.sls 
base:
  'server2':
    - apache.install
    - keepalived.install
  'server3':
    - nginx.service
    - keepalived.install

5.清除httpd推送文件与配置文件中的host选项(不然只监听本机的默认发布文件)

[root@server1 salt]# vim apache/install.sls 
[root@server1 salt]# cat apache/install.sls 
httpd:
  pkg.installed:
    - pkgs:
      - httpd
      - php
      - httpd-tools
  service.running:
    - name: httpd
    - enable: true

  file.managed:
    - name: /etc/httpd/conf/httpd.conf
    - source: salt://apache/files/httpd.conf
    - user: root
    - group: root
    - mode: 644
    - template: jinja
    - context:
      port: {{ pillar['port'] }}

[root@server1 salt]# vim apache/files/httpd.conf
在这里插入图片描述

  • 推送

[root@server1 salt]# salt ‘*’ state.highstate
在这里插入图片描述
在这里插入图片描述

  • 我们设定server2的优先级较高,设定的虚拟ip为172.25.32.100,首先在server2上查看vip是否存在并进行测试

查看vip(可以看到server2为vip)
在这里插入图片描述
在网页访问
在这里插入图片描述

  • 关闭server2的keepalived服务,vip漂移到server3

[root@server2 ~]# systemctl stop keepalived
在这里插入图片描述
在网页进行访问
在这里插入图片描述

  • 开启server1的keepalived服务再次测试
    在这里插入图片描述
    网页测试
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值