keepalived配置安装

什么是vrrp,阿里云不支持组播,所以阿里云上不能配置keepalived,但是它有自己的slb。
运维的大忌,在命令行复制粘贴,一般是先复制到文本中查看确认以后
salt编写配置管理keepalived之前,首先自己安装一遍

一、下载以及编译安装

  1. wget http://www.keepalived.org/software/keepalived-1.2.19.tar.gz
  2. tar zxf keepalived-1.2.19.tar.gz
  3. cd keepalived-1.2.19
  4. ./configure --prefix=/usr/local/keepalived --disable-fwmark
  5. make && make install

二、编写功能模块配置
1、创建keepalived配置管理相关目录

  1. mkdir /srv/salt/prod/keepalived
  2. mkdir /srv/salt/prod/leepalived/files
  3.  
  4. cd /usr/local/src/keepalived-1.2.19/keepalived/etc
  5. cp init.d/keepalived.init /srv/salt/prod/keepalived/files
  6. cp keeplived/keepalived.conf /srv/salt/prod/leepalived/files
  7.  
  8. keepalived文件位于编译安装后的目录下,该文件是keepalived后台运行配置文件
  9. cp /usr/local/keepalived/etc/sysconfig/keepalived /srv/salt/prod/leepalived/files/keepalived.sysconfig
  10. 或在解压目目录下也存在该文件
  11. cp keepalived/etc/init.d/keepalived.sysconfig /srv/salt/prod/keepalived/files/
  12. cp /usr/local/src/keepalived-1.2.19.tar.gz /srv/salt/prod/leepalived/files/

2、修改启动脚本

cd /srv/salt/prod/keepalived/files
vim keeplived.init

  1. daemon keeplived ${KEEPALIVED_OPTIONS}修改为
  2. daemon /usr/local/keepalived/sbin/keepalived ${KEEPALIVED_OPTIONS}

3、keepalived安装配置install.sls
cd /srv/salt/prod/keepalived
vim install.sls

  1. include:
  2. - pkg.pkg-init
  3. keepalived-install:
  4. file.managed:
  5. - name: /usr/local/src/keepalived-1.2.19.tar.gz
  6. - source: salt://keepalived/files/keepalived-1.2.19.tar.gz
  7. - user: root
  8. - group: root
  9. - mode: 755
  10. cmd.run:
  11. - name: cd /usr/local/src && tar zxf keepalived-1.2.19.tar.gz && cd keepalived-1.2.19 && ./configure --prefix=/usr/local/keepalived --disable-fwmark && make && make install
  12. - unless: test -d /usr/local/keepalived
  13. - require:
  14. - pkg: pkg-init
  15. - file: keepalived-install
  16. keepalived-init:
  17. file.managed:
  18. - name: /etc/init.d/keepalived
  19. - source: salt://keepalived/files/keepalived.init
  20. - user: root
  21. - group: root
  22. - mode: 755
  23. cmd.run:
  24. - name: chkconfig --add keepalived
  25. - unless: chkconfig --list | grep keepalived
  26. - require:
  27. - file: keepalived-init
  28. /etc/sysconfig/keepalived:
  29. file.managed:
  30. - source: salt://keepalived/files/keepalived.sysconfig
  31. - user: root
  32. - group: root
  33. - mode: 644
  34. /etc/keepalived:
  35. file.directory:
  36. - user: root
  37. - group: root
  38. - mode: 755

4、测试

  1. salt '*' state.sls keepalived.install env=prod test=True 

三、编写业务模块配置
1、编写keepalived的配置haproxy-outside-keepalived.conf
cd /srv/salt/prod/cluster/files
vim haproxy-outside-keepalived.conf

  1. ! Configuration File for keepalived
  2. global_defs {
  3. notification_email {
  4. saltstack@example.com
  5. }
  6. notification_email_from keepalived@example.com
  7. smtp_server 127.0.0.1
  8. smtp_connect_timeout 30
  9. # jinja模板变量
  10. router_id {{ROUTEID}}
  11. }
  12. vrrp_instance haproxy_ha {
  13. # jinja模板变量
  14. state {{STATEID}}
  15. interface eth0
  16. virtual_router_id 36
  17. # jinja模板变量
  18. priority {{PRIORITYID}}
  19. advert_int 1
  20. authentication {
  21. auth_type PASS
  22. auth_pass 1111
  23. }
  24. virtual_ipaddress {
  25. #虚ip
  26. 192.168.217.155
  27. }
  28. }

2、编写管理keepalived配置文件的sls
cd /srv/salt/prod/cluster/
vim haproxy-outside-keepalived.sls

  1. include:
  2. - keepalived.install
  3. keepalived-service:
  4. file.managed:
  5. - name: /etc/keepalived/keepalived.conf
  6. - source: salt://cluster/files/haproxy-outside-keepalived.conf
  7. - user: root
  8. - group: root
  9. - mode: 644
  10. - template: jinja
  11. {% if grains['fqdn'] == 'node1' %}
  12. - ROUTEID: haproxy_ha
  13. - STATEID: MASTER
  14. - PRIORITYID: 150
  15. {% elif grains['fqdn'] == 'node2' %}
  16. - ROUTEID: haproxy_ha
  17. - STATEID: BACKUP
  18. - PRIORITYID: 100
  19. {% endif %}
  20. service.running:
  21. - name: keepalived
  22. - enable: True
  23. - watch:
  24. - file: keepalived-service

3、配置完后的文件配置管理目录结构
│ ── base
│   ├── init
│   │   ├── audit.sls
│   │   ├── dns.sls
│   │   ├── env_init.sls
│   │   ├── files
│   │   │   └── resolv.conf
│   │   ├── history.sls
│   │   └── sysctl.sls
│   └── top.sls
├── prod
   ├── cluster
   │   ├── files
   │   │   ├── haproxy-outside.cfg
   │   │   └── haproxy-outside-keepalived.conf
   │   ├── haproxy-outside-keepalived.sls
   │   └── haproxy-outside.sls
   ├── haproxy
   │   ├── files
   │   │   ├── haproxy-1.6.2.tar.gz
   │   │   └── haproxy.init
   │   └── install.sls
   ├── keepalived
   │   ├── files
   │   │   ├── keepalived-1.2.19.tar.gz
   │   │   ├── keepalived.conf
   │   │   ├── keepalived.init
   │   │   └── keepalived.sysconfig
   │   └── install.sls
   └── pkg
   └── pkg-init.sls

4、测试
salt '*' state.sls cluster.haproxy-outside-keepalived env=prod test=True

5、在top.sls中加入keepalived

vim /srv/salt/base/top.sls

  1. base:
  2. '*':
  3. - init.env_init
  4. prod:
  5. "node1":
  6. - cluster.haproxy-outside
  7. - cluster.haproxy-outside-keepalived
  8. "node2":
  9. - cluster.haproxy-outside
  10. - cluster.haproxy-outside-keepalived

四、执行安装和配置keepalived以及vrrp测试查看
1、执行配置管理

  1. salt '*' state.highstate

2、虚ip查看如下截图

web访问结果

SaltStack自动化安装配置haproxy的Keepalived的更多相关文章

  1. saltstack自动化运维系列⑥SaltStack实践安装配置HAproxy的Keepalived

    saltstack自动化运维系列⑥SaltStack实践安装配置HAproxy的Keepalived 安装配置Keepalived 1.编写功能模块 #创建keepalived目录# mkdir -p ...

  2. SaltStack自动化安装配置haproxy

    准备环境node1:192.168.217.149 (saltstack master)node2:192.168.217.150(saltstack minion)下载haproxy1.6.2.ta ...

  3. saltstack自动化运维系列⑥SaltStack实践安装配置HAproxy

    saltstack自动化运维系列⑥SaltStack实践安装配置HAproxy 下载haproxy1.6.2.tar.gz下载地址:http://www.haproxy.org/download/1. ...

  4. Centos7.4安装配置haproxy和Keepalived

    系统版本是centos7.4的 [root@data-1-1 ~]# cat /etc/redhat-release CentOS Linux release 7.4.1708 (Core) [roo ...

  5. Centos7.4安装配置haproxy和Keepalived补充内容

    补充比较杂 1.当master服务恢复正常之后,backup机器收到消息,然后让出vip 下面是master机器服务恢复正常后,backup机器的Keepalived日志 收到master的消息通知, ...

  6. RabbitMQ集群安装配置+HAproxy+Keepalived高可用

    RabbitMQ集群安装配置+HAproxy+Keepalived高可用 转自:https://www.linuxidc.com/Linux/2016-10/136492.htm rabbitmq 集 ...

  7. SaltStack自动化安装zabbix-server

    使用SaltStack自动化安装zabbix-server 1,设置ntp时间同步 2,安装zabbix-agent 3,安装zabbix-server 4,安装及配置mariadb(mariadb与 ...

  8. NTP时间同步 服务端 客户端 自动化安装配置

    NTP时间同步 服务端 客户端 自动化安装配置 原创内容 http://www.cnblogs.com/elvi/p/7657994.html #!/bin/sh #运行环境 centos6.cent ...

  9. Linux系统实现ansible自动化安装配置httpd

    1.使用ansible的playbook实现自动化安装httpd 1)首先配置好ansible的hosts文件,让其对应主机能够受ansible控制 提示:我们在主机清单上配置了所管控的主机地址,但是 ...

随机推荐

  1. 股神小L

    题解 贪心 若当前手中还持有股,则一定会卖出去. 否则,考虑之前卖出的最便宜的股,若售价比当前的股高,就买下这个股,否则我们就把之前卖出的最便宜的股改为买入,这样一定会有股,然后再把这个股卖出即可. ...

  2. HihoCoder1338 A Game(记忆化搜索)

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 Little Hi and Little Ho are playing a game. There is an integ ...

  3. 【LeetCode】018 4Sum

    题目: Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = ...

  4. bzoj 3924 幻想乡战略游戏 —— 动态点分治

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3924 参考了博客:https://blog.csdn.net/qq_34564984/art ...

  5. winfrom实现控件全屏效果

    用常规方法实现全屏显示时,由于采用的三方控件导致界面顶端一直有一条半透明的类似标题栏的东西无法去除,原因一直没找到. 下面综合整理下网上两位博主的用WindowsAPI实现全屏的方法: 控件全屏显示: ...

  6. 为什么并行测试很困难以及如何使用 ConTest 辅助测试

    众所周知并行程序设计易于产生 bug.更为严重的是,往往在开发过程的晚期当这些并行 bug 引起严重的损害时才能发现它们并且难于调试它们.即使彻底地对它们进行了调试,常规的单元测试实践也很可能遗漏并行 ...

  7. Java接口定义和实现

    1. 使用interface来定义一个接口.接口定义类似类的定义,分为接口的声明和接口体,其中接口体由常量定义和方法定义两部分组成.定义接口的基本格式如下: [修饰符] interface 接口名 [ ...

  8. CentOS 7 配置 http 服务器

    一.http单域名访问 1.安装软件: yum -y install httpd 2.启动服务:systemctl  start httpd 3.设置开机启动: systemctl enable ht ...

  9. Dialog 自定义使用1

    一: 布局文件 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:andr ...

  10. easyui学习笔记1-(datagrid+dialog)

    jQuery EasyUI是一组基于jQuery的UI插件集合体.我的理解:jquery是js的插件,easyui是基于jquery的插件.用easyui可以很轻松的打造出功能丰富并且美观的UI界面. ...