利用ansible书写playbook搭建HAProxy+Keepalived+PXC负载均衡和高可用的PXC环境续
ansible、playbook、haproxy、keepalived、PXC
haproxy+keepalived双主模式调度pxc集群
HAProxy介绍
反向代理服务器,支持双机热备支持虚拟主机,但其配置简单,拥有非常不错的服务器健康检查功能,
当其代理的后端服务器出现故障, HAProxy会自动将该服务器摘除,故障恢复后再自动将该服务器加入
引入了frontend,backend;frontend根据任意 HTTP请求头内容做规则匹配,然后把请求定向到相关的backend.
Keepalived介绍
Keepalived是一个基于VRRP协议来实现的WEB 服务高可用方案,可以利用其来避免单点故障。
一个WEB服务至少会有2台服务器运行Keepalived,一台为主服务器(MASTER),
一台为备份服务器(BACKUP),但是对外表现为一个虚拟IP,主服务器会发送特定的消息给备份服务器,
当备份服务器收不到这个消息的时候,即主服务器宕机的时候,备份服务器就会接管虚拟IP,继续提供服务,从而保证了高可用性。
一、环境准备:
| proxy | 192.168.1.241(外网IP:139.9.219.*) | 跳板机(堡垒主机)、安装ansible、数据库客户端 |
| pxc-0001 | 192.168.1.181 | PXC数据库服务器角色 |
| pxc-0002 | 192.168.1.182 | PXC数据库服务器角色 |
| pxc-0003 | 192.168.1.183 | PXC数据库服务器角色 |
| ha-0001 | 192.168.1.171 | haproxy+keepalived |
| ha-0002 | 192.168.1.172 | haproxy+keepalived |
PXC集群搭建见随笔:https://www.cnblogs.com/jrjs/p/11764073.html
华为云云主机具体购买流程请浏览随笔:https://www.cnblogs.com/jrjs/p/11742221.html
在华为云购买台云主机ha-0001、ha-0002

添加俩个负载均衡器(elb-pxc1、elb-pxc2)

分别添加监听器、后端服务器组

添加监听器,让其监听3306端口。

添加后端服务器组,把ha-0001、ha-0002添加进来。采用加权轮询算法。

添加负载均衡器如下:
单击右上方购买增强型负载均衡



使用Xshell连接跳板机上配置ansible主机分组:

在跳板机上书写haproxy.cfg及keepalived.conf配置文件,通过playbook拷贝到俩台服务器上
haproxy.cfg配置文件如下:
[root@proxy ~]# vim /etc/haproxy/haproxy.cfg
global
log 127.0.0.1 local2 ##[err warning info debug]
chroot /usr/local/haproxy
pidfile /var/run/haproxy.pid ##haproxy的pid存放路径
maxconn ##最大连接数,默认4000
user haproxy
group haproxy
daemon ##创建1个进程进入deamon模式运行
defaults
mode tcp ##默认的模式mode { tcp|http|health }
option dontlognull ##不记录健康检查的日志信息
option httpclose ##每次请求完毕后主动关闭http通道
option httplog ##日志类别http日志格式
option forwardfor ##后端服务器可以从Http Header中获得客户端ip
option redispatch ##serverid服务器挂掉后强制定向到其他健康服务器
timeout connect #如果backend没有指定,默认为10s
timeout client ##客户端连接超时
timeout server ##服务器连接超时
maxconn ##最大连接数
retries ##3次连接失败就认为服务不可用,也可以通过后面设置 listen stats 0.0.0.0: #监听端口
stats refresh 30s #统计页面自动刷新时间
stats uri /stats #统计页面url
stats realm Haproxy Manager #进入管理解面查看状态信息
stats auth admin:admin #统计页面用户名和密码设置 listen pxcsrv-rewrite 0.0.0.0:
balance roundrobin
server pxc- 192.168.1.181: check inter rise fall
server pxc- 192.168.1.182: check inter rise fall
server pxc- 192.168.1.183: check inter rise fall
keepalived.conf配置文件如下:
! Configuration File for keepalived
global_defs {
notification_email {
root@localhost //设置报警收件人邮箱
vrrp_iptables
}
notification_email_from Alexandre.Cassen@firewall.loc //设置发件人
smtp_server 192.168.200.1 //定义邮件服务器
smtp_connect_timeout
router_id LVS_DEVEL //设置路由ID号
}
vrrp_instance VI_1 {
state MASTER //主服务器为MASTER(ha-0002备服务器需要修改为BACKUP)
interface eth0 //定义网络接口
virtual_router_id //主备服务器VRID号必须一致
priority //服务器优先级,优先级高优先获取VIP
advert_int
authentication {
auth_type PASS
auth_pass //主备服务器密码必须一致
}
virtual_ipaddress { //谁是主服务器谁获得该VIP,当主服务器宕掉VIP自动飘到备服务器上
192.168.1.48/ brd 192.168.1.255 dev eth0 label eth0:
}
}
vrrp_instance VI_2 {
state BACKUP //备服务器为BACKUP(ha-0001主服务器需要修改为MASTER)
interface eth0 //定义网络接口
virtual_router_id //主备服务器VRID号必须一致
priority //服务器优先级,优先级高优先获取VIP
advert_int
authentication {
auth_type PASS
auth_pass //主备服务器密码必须一致
}
virtual_ipaddress { //谁是主服务器谁获得该VIP,当主服务器宕掉VIP自动飘到备服务器上
192.168.1.49/ brd 192.168.1.255 dev eth0 label eth0:
}
}
然后在跳板机书写playbook,playbook具体内容如下:
---
#安装haproxy,keepalived相关软件包
- hosts: ha+kp
tasks:
- name: installed haproxy,keepalived
yum:
name: haproxy,keepalived
state: installed
#在跳板机上编辑haproxy配置文件,拷贝到俩台服务器上
- name: copy haproxy
copy:
src: /root/haproxy.cfg
dest: /etc/haproxy/haproxy.cfg
#在跳板机上编辑keepalived配置文件,拷贝到俩台服务器上
- name: copy keepalived
copy:
src: /root/keepalived.conf
dest: /etc/keepalived/keepalived.conf
#修改keepalived.conf配置文件
- hosts: ha-
tasks:
- name: modify keepalived.conf
replace:
path: "/etc/keepalived/keepalived.conf"
regexp: "MASTER"
replace: "linshi"
- replace:
path: "/etc/keepalived/keepalived.conf"
regexp: "BACKUP"
replace: "MASTER"
- replace:
path: "/etc/keepalived/keepalived.conf"
regexp: "linshi"
replace: "BACKUP"
- replace:
path: "/etc/keepalived/keepalived.conf"
regexp: ""
replace: ""
- replace:
path: "/etc/keepalived/keepalived.conf"
regexp: ""
replace: ""
- replace:
path: "/etc/keepalived/keepalived.conf"
regexp: ""
replace: ""
#启动haproxy、keepalived服务
- hosts: ha+kp
tasks:
- name: start haproxy
service:
name: haproxy
enabled: yes
state: started
- name: start keepalived
service:
name: keepalived
enabled: yes
state: started
运行完成后在ha-0001查看haproxy服务是否启动:

查看ha-0001上的keepalived服务是否启动

运行完成后在ha-0002查看haproxy服务是否启动:

查看ha-0002上的keepalived服务是否启动

在ha-0001、ha-0002上使用ip a s命令,查看设置的vip48、49是否生效:


在跳板机访问ha-0001或者ha-0002的vip是否可以访问到:


到此haproxy+keepalived双主模式配置成功,成功的让俩台服务器同时工作,减轻单台调度器的压力,也实现了资源的合理利用。
利用ansible书写playbook搭建HAProxy+Keepalived+PXC负载均衡和高可用的PXC环境续的更多相关文章
- HAProxy+Keepalived+PXC负载均衡和高可用的PXC环境
HAProxy介绍 反向代理服务器,支持双机热备支持虚拟主机,但其配置简单,拥有非常不错的服务器健康检查功能,当其代理的后端服务器出现故障, HAProxy会自动将该服务器摘除,故障恢复后再自动将该服 ...
- LVS + keepalived + tomcat负载均衡及高可用实现(初级)
1.首先检测Linux服务器是否支持ipvs 执行如下命令:modprobe -l|grep ipvs 输出: kernel/net/netfilter/ipvs/ip_vs.ko kernel/ne ...
- HAProxy+keepalived+MySQL 实现MHA中slave集群负载均衡的高可用
HAProxy+keepalived+MySQL实现MHA中slave集群的负载均衡的高可用 Ip地址划分: 240 mysql_b2 242 mysql_b1 247 haprox ...
- Keepalived+LVS+Nginx负载均衡之高可用
Keepalived+LVS+Nginx负载均衡之高可用 上一篇写了nginx负载均衡,此篇实现高可用(HA).系统整体设计是采用Nginx做负载均衡,若出现Nginx单机故障,则导致整个系统无法正常 ...
- Net分布式系统之三:Keepalived+LVS+Nginx负载均衡之高可用
上一篇写了nginx负载均衡,此篇实现高可用(HA).系统整体设计是采用Nginx做负载均衡,若出现Nginx单机故障,则导致整个系统无法正常运行.针对系统架构设计的高可用要求,我们需要解决Nginx ...
- haproxy+tomcat实现负载均衡以及session共享(linux centos7环境)
一.安装HAProxy 1.进入home目录,下载最新haproxy安装包. cd /home wget http://haproxy.1wt.eu/download/1.4/src/haproxy- ...
- 利用ansible书写playbook在华为云上批量配置管理工具自动化安装ceph集群
首先在华为云上购买搭建ceph集群所需云主机: 然后购买ceph所需存储磁盘 将购买的磁盘挂载到用来搭建ceph的云主机上 在跳板机上安装ansible 查看ansible版本,检验ansible是否 ...
- MySQL架构之keepalived+haproxy+mysql 实现MHA中slave集群负载均衡的高可用(原创)
MySQL的高可用方案一般有如下几种:keepalived+双主,MHA,PXC,MMM,Heartbeat+DRBD等,比较常用的是keepalived+双主,MHA和PXC. HAProxy是一款 ...
- HaProxy+keepalived实现负载均衡
HAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持 ...
随机推荐
- Qt开发经验小技巧61-70
很多人问Qt嵌入式平台用哪个好,这里统一回答(当前时间节点2018年):imx6+335x比较稳定,性能高就用RK3288 RK3399,便宜的话就用全志H3,玩一玩可以用树莓派香橙派. 对于大段的注 ...
- python时间戳,获取当前时间,时间格式转换,求出前几天或后几天的时间
import time import datetime import locale import random class TimeUtil: def __init__(self, curtime=N ...
- (十二)springboot中shiro的使用
一.引入maven配置 <dependency> <groupId>org.apache.shiro</groupId> <artifactI ...
- 升级go mod采坑录
为了使用go mod把golang升级到了最新的1.12版本,go mod是1.11版本引入的,go mod的引入极大的方便了golang项目的依赖管理,同时把golang项目从GOPATH中解放了出 ...
- Android 横竖屏切换处理
最近在做一个平板项目,有横竖屏切换的问题,写一下处理的方法. 第一种:禁止横竖屏切换. 对于单独的Activity,使用下面的方式直接配置: <activity android:name=&qu ...
- STL源码之traits编程技法
摘要 主要讨论如何获取迭代器相应型别.使用迭代器时,很可能用到其型别,若需要声明某个迭代器所指对象的型别的变量,该如何解决.方法如下: function template的参数推导机制 例如: tem ...
- c++中共享内存原理及实现
共享内存 (也叫内存映射文件) 主要是通过映射机制实现的 , Windows 下进程的地址空间在逻辑上是相互隔离的 , 但在物理上却是重叠的 ; 所谓的重叠是指同一块内存区域可能被多个进程同时使用 , ...
- 【剑指offer】数组中只出现一次的数
题目描述 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字. 分析: 经典的异或技巧题 两个相同的数字异或的结果为0,一个数和0异或的结果是其本身,假设现在那 ...
- Sqlserver (转载)事物与锁
1 概述 本篇文章简要对事物与锁的分析比较详细,因此就转载了. 2 具体内容 并发可以定义为多个进程同时访问或修改共享数据的能力.处于活动状态而互不干涉的并发用户进程的数量越多,数据库系统的并 ...
- day55——django引入、小型django(socket包装的服务器)
day55 吴超老师Django总网页:https://www.cnblogs.com/clschao/articles/10526431.html 请求(网址访问,提交数据等等) request 响 ...