这里使用keepalived实现mysql的双主热备高可用

实验环境:

主机名

IP

系统版本

软件版本

master

192.168.199.6/vip:192.168.199.111

Rhel7.4

Mysql8.0.17+Keepalived v1.3.5

openStack

192.168.199.7/vip:192.168.199.111

Rhel7.4

Mysql8.0.17+Keepalived v1.3.5

一、MySQL主主同步部署:

master上操作

[root@master ~]# grep -v '^#' /etc/my.cnf

[mysqld]

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock

log-error=/var/log/mysqld.log

pid-file=/var/run/mysqld/mysqld.pid

server-id=1

gtid-mode=on

enforce-gtid-consistency=on

log-slave-updates=on

log_bin = binlog

[root@master ~]# systemctl start mysqld

[root@master ~]# mysql -uroot -p密码

mysql> create user 'repl'@'192.168.199.%' identified with mysql_native_password by 'kavl7kAkkle!';

mysql> grant replication slave on *.* to 'repl'@'192.168.199.%';

mysql> flush privileges;

Openstack上操作:

[root@openstack ~]# grep -v '^#' /etc/my.cnf

[mysqld]

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock

log-error=/var/log/mysqld.log

pid-file=/var/run/mysqld/mysqld.pid

server-id=1

gtid-mode=on

enforce-gtid-consistency=on

log-slave-updates=on

log_bin = binlog

[root@master ~]# systemctl start mysqld

[root@master ~]# mysql -uroot -p密码

mysql> create user 'repl'@'192.168.199.%' identified with mysql_native_password by 'kavl7kAkkle!';

mysql> grant replication slave on *.* to 'repl'@'192.168.199.%';

mysql> flush privileges;

Master上操作:

mysql> change master to master_host='192.168.199.7',master_user='repl',master_password='kavl7kAkkle!';     指定主库IP,使用的用户,密码
mysql> start slave;

mysql> show slave status\G;

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.199.7

Master_User: repl

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: binlog.000002

Read_Master_Log_Pos: 697

Relay_Log_File: master-relay-bin.000008

Relay_Log_Pos: 647

Relay_Master_Log_File: binlog.000002

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Openstack上操作:

mysql> change master to master_host='192.168.199.6',master_user='repl',master_password='kavl7kAkkle!';     指定主库IP,使用的用户,密码
mysql> start slave;

mysql> show slave status\G;

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.199.6

Master_User: repl

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: binlog.000003

Read_Master_Log_Pos: 692

Relay_Log_File: openstack-relay-bin.000008

Relay_Log_Pos: 570

Relay_Master_Log_File: binlog.000003

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

二、配置mysql+keepalived高可用环境

Master上操作:

[root@master ~]# yum -y install keepalived

[root@master ~]# more /etc/keepalived/keepalived.conf

! Configuration File for keepalived

global_defs {

router_id MASTER-HA

}

vrrp_script check_mysql_port {

script "/etc/keepalived/check_mysql.sh"

interval 2

weight -5

fall 2

rise 1

}

vrrp_instance VI_1 {

state MASTER

interface ens32

virtual_router_id 51

priority 101

advert_int 1

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.199.111

}

track_script {

check_mysql_port

}

}

Openstack上操作:

[root@openstack ~]# yum -y install keepalived

[root@openstack ~]# vim /etc/keepalived/keepalived.conf

! Configuration File for keepalived

global_defs {

router_id MASTER-HA

}

vrrp_script check_mysql_port {

script "/etc/keepalived/check_mysql.sh"

interval 2

weight -5

fall 2

rise 1

}

vrrp_instance VI_1 {

state BACKUP

interface ens33

virtual_router_id 51

priority 10

advert_int 1

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.199.111

}

track_script {

check_mysql_port

}

}

切换脚本,keepalived做心跳检测,如果mysql服务挂了,就会停掉进程,此时从的keepalived做心跳检测会发现这个情况,VIP就会切换到从上。

[root@openstack ~]# vim /etc/keepalived/check_mysql.sh

#!/bin/bash

counter=$(netstat -na|grep "LISTEN"|grep "3306"|wc -l)

if [ "${counter}" -eq 0 ]; then

systemctl stop keepalived.service

fi

启动keepalived。

[root@master ~]# systemctl startkeepalived.service

[root@openstack ~]# systemctl start keepalived.service

三、创建应用账号:

[root@master ~]# mysql -uroot -pkavl7kAkkle!

mysql> create database hke;

mysql> create user 'yingyong'@'192.168.199.%' identified with mysql_native_password by 'kavl7kAkkle!';

mysql> grant all on hke.* to 'yingyong'@'192.168.199.%';

四、Mysql+keepalived故障转移的高可用测试:

通过mysql客户端通过VIP连接,查看是否能够连接成功。

[root@winter ~]# mysql -uyingyong -pkavl7kAkkle! -h 192.168.199.111

mysql> select @@hostname;

+------------+

| @@hostname |

+------------+

| master     |

+------------+

1 row in set (0.00 sec)

mysql> show databases;

+--------------------+

| Database           |

+--------------------+

| hke                |

| information_schema |

+--------------------+

2 rows in set (0.01 sec)

mysql> select * from hke.hke_user;

+----+---------+

| id | name    |

+----+---------+

|  1 | thunder |

|  2 | winter  |

|  3 | qq      |

+----+---------+

3 rows in set (0.04 sec)

默认情况下VIP是在master上的

[root@master ~]# ip a

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1

link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

inet 127.0.0.1/8 scope host lo

valid_lft forever preferred_lft forever

inet6 ::1/128 scope host

valid_lft forever preferred_lft forever

2: ens32: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

link/ether 00:0c:29:7d:60:e3 brd ff:ff:ff:ff:ff:ff

inet 192.168.199.6/24 brd 192.168.199.255 scope global ens32

valid_lft forever preferred_lft forever

inet 192.168.199.111/32 scope global ens32

valid_lft forever preferred_lft forever

inet6 fe80::97dd:b327:4a4e:afdb/64 scope link

valid_lft forever preferred_lft forever

停掉主的数据库:

mysql服务停了,keepalived也会停,从而vip资源将会切换到master2机器上。

[root@master ~]# systemctl stop mysqld

[root@master ~]# netstat -tlunp|grep mysqld

[root@master ~]# ps -ef|grep keepalived

root      80720  62500  0 21:43 pts/3    00:00:00 grep --color=auto keepalived

在master上查看地址,此时已经没有VIP了。

[root@master ~]# ip a

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1

link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

inet 127.0.0.1/8 scope host lo

valid_lft forever preferred_lft forever

inet6 ::1/128 scope host

valid_lft forever preferred_lft forever

2: ens32: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

link/ether 00:0c:29:7d:60:e3 brd ff:ff:ff:ff:ff:ff

inet 192.168.199.6/24 brd 192.168.199.255 scope global ens32

valid_lft forever preferred_lft forever

inet6 fe80::97dd:b327:4a4e:afdb/64 scope link

valid_lft forever preferred_lft forever

在openstack查看网卡地址:

[root@openstack ~]# ip a

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1

link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

inet 127.0.0.1/8 scope host lo

valid_lft forever preferred_lft forever

inet6 ::1/128 scope host

valid_lft forever preferred_lft forever

2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

link/ether 00:0c:29:73:f6:6b brd ff:ff:ff:ff:ff:ff

inet 192.168.199.7/24 brd 192.168.199.255 scope global ens33

valid_lft forever preferred_lft forever

inet 192.168.199.111/32 scope global ens33

valid_lft forever preferred_lft forever

inet6 fe80::b4bd:5e9f:2805:dfe/64 scope link

valid_lft forever preferred_lft forever

在mysql客户端通过VIP连接,查看连接信息:

[root@winter ~]# mysql -uyingyong -pkavl7kAkkle! -h 192.168.199.111

mysql> select @@hostname;   此时连接的是从

+------------+

| @@hostname |

+------------+

| openstack  |

+------------+

1 row in set (0.01 sec)

再次启动主上的mysql和keepalived

[root@master ~]# systemctl start mysqld

[root@master ~]# systemctl start keepalived.service

[root@master ~]# ps -ef|grep mysqld|grep -v 'grep'

mysql     80918      1 15 21:57 ?        00:00:17 /usr/sbin/mysqld

[root@master ~]# ps -ef|grep keepalived |grep -v 'grep';

root      80990      1  0 21:58 ?        00:00:00 /usr/sbin/keepalived -D

root      80991  80990  0 21:58 ?        00:00:00 /usr/sbin/keepalived -D

root      80992  80990  0 21:58 ?        00:00:00 /usr/sbin/keepalived -D

查看master上的网卡:

[root@master ~]# ip a

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1

link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

inet 127.0.0.1/8 scope host lo

valid_lft forever preferred_lft forever

inet6 ::1/128 scope host

valid_lft forever preferred_lft forever

2: ens32: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

link/ether 00:0c:29:7d:60:e3 brd ff:ff:ff:ff:ff:ff

inet 192.168.199.6/24 brd 192.168.199.255 scope global ens32

valid_lft forever preferred_lft forever

inet 192.168.199.111/32 scope global ens32

valid_lft forever preferred_lft forever

inet6 fe80::97dd:b327:4a4e:afdb/64 scope link

valid_lft forever preferred_lft forever

VIP已经漂移过来了。

再在从上查看此时已经没有VIP了。

[root@openstack ~]# ip a

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1

link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

inet 127.0.0.1/8 scope host lo

valid_lft forever preferred_lft forever

inet6 ::1/128 scope host

valid_lft forever preferred_lft forever

2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

link/ether 00:0c:29:73:f6:6b brd ff:ff:ff:ff:ff:ff

inet 192.168.199.7/24 brd 192.168.199.255 scope global ens33

valid_lft forever preferred_lft forever

inet6 fe80::b4bd:5e9f:2805:dfe/64 scope link

valid_lft forever preferred_lft forever

在mysql客户端通过VIP连接,查看连接信息:

[root@winter ~]# mysql -uyingyong -pkavl7kAkkle! -h 192.168.199.111

mysql> select @@hostname;  此时连接的主

+------------+

| @@hostname |

+------------+

| master     |

+------------+

1 row in set (0.00 sec)

keepalived+mysql双主热备的更多相关文章

  1. Mysql + keepalived 实现双主热备读写分离【转】

    Mysql + keepalived 实现双主热备读写分离 2013年6月16日frankwong发表评论阅读评论   架构图 系统:CentOS6.4_X86_64软件版本:Mysql-5.6.12 ...

  2. 高可用Mysql架构_Mysql主从复制、Mysql双主热备、Mysql双主双从、Mysql读写分离(Mycat中间件)、Mysql分库分表架构(Mycat中间件)的演变

    [Mysql主从复制]解决的问题数据分布:比如一共150台机器,分别往电信.网通.移动各放50台,这样无论在哪个网络访问都很快.其次按照地域,比如国内国外,北方南方,这样地域性访问解决了.负载均衡:M ...

  3. MySQL双主热备问题处理

    1. Slave_IO_Running: No mysql> show slave status\G *************************** 1. row *********** ...

  4. Mysql双主热备+LVS+Keepalived高可用部署实施手册

    MySQL复制能够保证数据的冗余的同时可以做读写分离来分担系统压力,如果是主主复制还可以很好的避免主节点的单点故障.然而MySQL主主复制存在一些问题无法满足我们的实际需要:未提供统一访问入口来实现负 ...

  5. Mysql双主热备+LVS+Keepalived高可用操作记录

    MySQL复制能够保证数据的冗余的同时可以做读写分离来分担系统压力,如果是主主复制还可以很好的避免主节点的单点故障.然而MySQL主主复制存在一些问题无法满足我们的实际需要:未提供统一访问入口来实现负 ...

  6. mysql双主热备

    先搭建mysql主从模式,主从请参考mysql 主从笔记 然后在在配置文件里添加如下配置 1 log_slave_updates= #双主热备的关键参数.默认情况下从节点从主节点中同步过来的修改事件是 ...

  7. Mysql主从复制,双主热备

    Mysql主从复制: 主从复制: 主机准备工作: 开启bin.Log 注意:server-id  是唯一的值 重启mysql:service mysql restart 查看是否开启成功: 查看当前状 ...

  8. 使用Keepalived实现Nginx的自动重启及双主热备高可用

    1.概述 之前我们使用Keepalived实现了Nginx服务的双机主备高可用,但是有几个问题没有解决,今天一起探讨一下. 1)在双机主备机制中,Keepalived服务如果宕了,会自动启用备机进行服 ...

  9. Mysql+Keepalived双主热备高可用操作记录

    我们通常说的双机热备是指两台机器都在运行,但并不是两台机器都同时在提供服务.当提供服务的一台出现故障的时候,另外一台会马上自动接管并且提供服务,而且切换的时间非常短.MySQL双主复制,即互为Mast ...

随机推荐

  1. 在论坛中出现的比较难的sql问题:7(子查询 判断某个字段的值是否连续)

    原文:在论坛中出现的比较难的sql问题:7(子查询 判断某个字段的值是否连续) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以 ...

  2. C#从零单排上王者系列---元组

    从零单排系列说明 博主最初的想法是想写个蜕茧成蝶的系列文章,后来觉得博客的表现形式很难做到连贯和系统.所以从本篇博客开始博主会选择书中比较重要和不好理解的知识点并结合自己的实际工作经验来讲解,不再是照 ...

  3. 通过Kubeadm搭建Kubernetes集群

    历经断断续续学习的两天,终于完成了一个简单k8s集群. 参考 https://www.cnblogs.com/edisonchou/p/aspnet_core_on_k8s_deepstudy_par ...

  4. nodejs入门API之url模块+querystring模块

    关于URL的一些基础内容 URL模块的API解析 URL的参数URLSearchParams类 querystring模块 一.关于URL的一些基础内容 1.1 定义: 在WWW上,每一信息资源都有统 ...

  5. Linux Centos7配置mysql8.0数据库

    本文转至:672530440 在此感谢博主,撒花!!! 本文主要从以下几个方面对自己在centos7 下安装mysql8过程做如下总结: CentOS7 安装mysql8 步骤: window下的Na ...

  6. Bootstrap模态框报错

    解决方案:上面的问题主要是包的引入问题,要确保上面的包多已经引入,我就是在引入jquery包时,引入了2个重复的包,去掉其中的一个,问题解决了.

  7. 转:applicationContext.xml文件放置位置不同而导致的jUnit测试的时候路径的不同

    如果applicationContext.xml文件放置在src下面的的时候使用jUint测试的时候编写的路径应该是这样的: @Test public void saveTest() { Applic ...

  8. Spark学习笔记2——RDD(上)

    目录 Spark学习笔记2--RDD(上) RDD是什么? 例子 创建 RDD 并行化方式 读取外部数据集方式 RDD 操作 转化操作 行动操作 惰性求值 Spark学习笔记2--RDD(上) 笔记摘 ...

  9. nginx__的简单搭建和 wsgi

    4 部署 1 配置 uwsig(配置文件) pip3 install uwsgi 1 mkdir uwsgi 2 cd uwsgi 3 touch test_uwsig.ini [uwsgi] # 指 ...

  10. 持续集成工具FinalBuilder使用心得

    FinalBuilder 使用这款自动化创建和发布管理工具,软件开发者可以定义和维护一个可靠的以及可重复创建的程序.FinalBuilder包括集成的带有版本的控制系统,文件和目录选项,重复器,源代码 ...