Saltsack实现apache+nginx+keepalived高可用

本博文在Saltstack推送httpd服务 与 nginx服务基础上:
环境

server1:salt-master172.25.60.1
server2:salt-minion httpd keepalived172.25.60.2
server3:salt-minion nginx keepalived172.25.60.3

实验准备:

恢复httpd端口
vim /srv/salt/apache/files/httpd.conf 
Listen 80    

1.在base目录下面建立keepalived目录,并建立install.sls文件

mkdir /srv/salt/keepalived
cd keepalived/
cp ../apache/install.sls .
vim install.sls
install-keepalived:
  pkg.installed:
    - pkgs:
      -  keepalived
 
  file.managed:
    - name: /etc/keepalived/keepalived.conf
    - source: salt://keepalived/files/keepalived.conf
    - template: jinja             ##使用jinja模板
    - context:
      STATE: {{ pillar['state'] }}
      VRID: {{ pillar['vrid'] }}
      PRIORITY: {{ pillar['priority'] }}
 
  service.running:
    - name: keepalived
    - watch:
      - file: install-keepalived

在这里插入图片描述
2.创建files目录,拷贝keepalived.conf模板文件到files目录

[root@server1 keepalived]# mkdir files
[root@server1 keepalived]# yum install -y keepalived
[root@server1 keepalived]# cd files
[root@server1 files]# cp /etc/keepalived/keepalived.conf .
[root@server1 files]# vim keepalived.conf 
[root@server1 files]# cat keepalived.conf 
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 }}
    priority {{ PRIORITY }}
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        172.25.60.100
    }
}

在这里插入图片描述
3.在pillar/web目录下,设置变量的取值

[root@server1 files]# cd /srv/pillar/
[root@server1 pillar]# vim web/vars.sls 
[root@server1 pillar]# cat web/vars.sls
{% if grains['fqdn'] == 'server2' %}
state: MASTER
vrid: 60
priority: 100
{% elif grains['fqdn'] == 'server3' %}
state: BACKUP
vrid: 60
priority: 50
{% endif %}

在这里插入图片描述
4.设置主推送文件top.sls

[root@server1 pillar]# vim /srv/salt/top.sls 
[root@server1 pillar]# cat /srv/salt/top.sls
base:
  'roles:apache':
    - match: grain
    - apache.install
    - keepalived.install
  'roles:nginx':
    - match: grain
    - nginx.service
    - keepalived.install

在这里插入图片描述
向server2和server3推送keepalived
salt ‘*’ state.highstate
在这里插入图片描述查看高可用集群是否搭建完毕
server2为master,在server2中查看虚拟ip
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
server2中编写httpd默认发布文件
echo hello westos > /var/www/html/index.html
浏览器中访问http://172.25.60.100,默认访问的页面是server2中的内容
在这里插入图片描述
systemctl stop keepalived

在这里插入图片描述
将server2中的keepalived关闭,我们会发现虚拟ip漂移到server3中,且访问172.25.60.100时,显示的页面内容是server3中nginx的欢迎页面
在这里插入图片描述

在这里插入图片描述

再次开启server2中的keepalived服务,由于优先级的原因,虚拟ip会回到server2中

在这里插入图片描述在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值