keepalived Mariadb(mysql) 实现双主 高可用(HA)

时间:2022-09-15 07:43:27

此文整理了网上的文章  并加以修改 亲测可用


利用keepalived构建高可用MySQL-HA,保证两台MySQL数据的一致性,然后用keepalived实现虚拟VIP,通过keepalived自带的服务监控功能来实现MySQL故障时自动切换。

 

 关于MySQL-HA,目前有多种解决方案,比如heartbeatdrbdmmm、共享存储,但是它们各有优缺点。heartbeatdrbd配置较为复杂,需要自己写脚本才能实现MySQL自动切换,对于不会脚本语言的人来说,这无疑是一种脑裂问题;对于mmm,生产环境中很少有人用,且mmm管理端需要单独运行一台服务器上,要是想实现高可用,就得对mmm管理端做HA,这样无疑又增加了硬件开支;对于共享存储,个人觉得MySQL数据还是放在本地较为安全,存储设备毕竟存在单点隐患。使用MySQLmaster+keepalived是一种非常好的解决方案,在MySQL-HA环境中,MySQL互为主从关系,这样就保证了两台MySQL数据的一致性,然后用keepalived实现虚拟IP,通过keepalived自带的服务监控功能来实现MySQL故障时自动切换

 

硬件拓扑如下:

 

VIP192.168.1.200

mysql1:192.168.1.201

mysql2:192.168.1.202

 

操作系统:CentOS release 6.332位)

MySQL版本:MariaDB 5.5.31 Stable

下载地址(64位请下载64版本)https://downloads.mariadb.org/f/mariadb-5.5.31/kvm-tarbake-jaunty-x86/mariadb-5.5.31.tar.gz/from/http:/mirrors.scie.in/mariadb

Keepalived版本:Version 1.2.7

下载地址:http://www.keepalived.org/software/keepalived-1.2.7.tar.gz

 (下载地址不对 可以在网上搜一个

一、配置Centos运行环境:

 

执行:

rpm -qa|grep mysql

rpm -e mysql

yum -y remove mysql-server mysql

yum -y remove php-mysql

移除系统自带的mysql

 (没有 不需移除 )

yum -y install yum-fastestmirror

yum -y update

更新系统软件;

 

rm -rf /etc/localtime

ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

 

yum install -y ntp

ntpdate -d cn.pool.ntp.org

date

设置时区并同步系统时间

设置免密登录 

(网上例子没有免密码登录  这个是行不通的)

(集群 三要素  时间同步 防火墙关闭  免密码登录)

关闭安全增强

(设置SELINUX = disabled


cat >>/etc/security/limits.conf<<eof

* soft nproc 65535

* hard nproc 65535

* soft nofile 65535

* hard nofile 65535

eof

 

cat >>/etc/sysctl.conf<<eof

fs.file-max=65535

eof

修改文件句柄的最大数量

 

安装一些必备软件

yum -y install gcc gcc-c++ gcc-g77 ncurses-devel bison libaio-devel cmake libnl* libpopt* popt-static openssl-devel

 

本人此处有sambo-common包冲突

直接 yum  remove

二、安装maridDB

 

1、下载相关软件源码包

[root@localhost down]# wget  ******* 

网上下载一个

 

2、配置编译器,提高性能

CFLAGS="-O3"

CXX=gcc

CXXFLAGS="-O3 -felide-constructors -fno-exceptions -fno-rtti"

 (此处没找到在哪配置的  可以忽略)

 

 

3、开始安装mariadb

添加mysql用户和用户组

[root@localhost down]# groupadd mysql

[root@localhost down]# useradd -s /sbin/nologin -M -g mysql mysql

 

解压mariadb

[root@localhost down]# tar -zxvf mariadb-5.5.31.tar.gz

[root@localhost down]# cd mariadb-5.5.31

 

安装到/usr/local/mariamysql目录:

mkdir /usr/local/mariamysql

[root@localhost mariadb-5.5.31]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mariamysql -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_FEDERATED_STORAGE_ENGINE=1  -DENABLED_LOCAL_INFILE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci   -DWITH_DEBUG=0 -DBUILD_CONFIG=mysql_release -DFEATURE_SET=community -DWITH_EMBEDDED_SERVER=OFF && make && make install

 

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

 

 

复制配置文件到/etc/my.cnf

[root@localhost down]# cp /usr/local/mariamysql/support-files/my-huge.cnf /etc/my.cnf

 

设置mariamysql为系统服务

[root@localhost down]# cp /usr/local/mariamysql/support-files/mysql.server /etc/init.d/mariamysql

 

初始化mariaDB数据库:

[root@localhost down]# /usr/local/mariamysql/scripts/mysql_install_db --basedir=/usr/local/mariamysql/ --datadir=/usr/local/mariamysql/data/ --user=mysql

 

至此mariaDB安装完成。

 

三、keepalived安装:

 

1、下载源码包:

wget http://www.keepalived.org/software/keepalived-1.2.7.tar.gz

keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

2、安装:

[root@localhost down]# tar -zxvf keepalived-1.2.7.tar.gz

[root@localhost down]# cd keepalived-1.2.7

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

[root@localhost keepalived-1.2.7]#  ./configure --prefix=/usr/local/keepalived

 make && make install

安装到/usr/local/keepalived目录下;

至此keepalived安装完毕。

 

 

四、分别在201202两台机器上都重复二,三安装好mariaDBkeepalived

 

 

五、配置201数据库服务器:

 

1、设置mariaDB数据库配置文件:

[root@localhost /]# vi /etc/my.cnf 

确保/etc/my.cnf中有如下参数,没有的话需手工添加,并重启mysql服务。

[mysqld]
log-bin=mysql-bin 

#启动二进制文件
server-id=1 

#服务器ID

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

设置完毕启动mariaDB服务器

 

[root@localhost /]# service mariamysql start

 

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

2、登录mysql,然后在增加一个账号专门用于同步,如下:

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

[root@localhost /]# /usr/local/mariamysql/bin/mysql -uroot -p  #初始密码为空到Enter password:处直接回车即可

MariaDB [(none)]> grant replication slave on *.* to 'backup'@'192.168.1.202' identified by 'backup'; flush privileges;

 

显示master状态:

MariaDB [(none)]> show master status;

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

记录下FilePosition然后在202上面设置从201同步。

 

 

六、配置202数据库服务器:

 

[root@localhost /]# vi /etc/my.cnf 

确保/etc/my.cnf中有如下参数,没有的话需手工添加,并重启mysql服务。

[mysqld]
log-bin=mysql-bin 

#启动二进制文件
server-id=10(此处要设置的跟201不同)

#服务器ID

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

设置完毕启动mariaDB服务器。

[root@localhost /]# service mariamysql start

登录数据库:

[root@localhost /]# /usr/local/mariamysql/bin/mysql -uroot -p 

输入:

MariaDB [(none)]> change master to master_host='192.168.1.201',master_user='backup',master_password='backup',master_log_file='mysql-bin.000010',master_log_pos=245;

注意:245对应上面在201上面记下的Position,mysql-bin.000010对应201上面记录的File

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

执行成功后,输入命令显示从库状态:

MariaDB [(none)]> show slave status \G;

 

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

Slave_IO_Running: Yes            

Slave_SQL_Running: Yes

两项都显示Yes时说明从201同步数据成功。

至此201为主202为从的主从架构数据设置成功!

 

七、设置201202互为主从:

 

1202机器上增加一个帐号专门用于同步数据:

MariaDB [(none)]> grant replication slave on *.* to 'backup'@'192.168.1.201' identified by 'backup'; flush privileges;

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

2、显示202做为主库时的状态:

MariaDB [(none)]> show master status;

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

3、在201数据库服务器上:

 

stop  slave;

MariaDB [(none)]> change master to master_host='192.168.1.202',master_user='backup',master_password='backup',master_log_file='mysql-bin.000005',master_log_pos=5005;

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

start  slave;

不执行 stop  slave_io_runing  slave_sql_runing  NO

 

注意:5005对应上面在202上面记下的Position,mysql-bin.000005对应202上面记录的File

显示状态:

MariaDB [(none)]> show slave status \G;

 

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

Slave_IO_Running: Yes            

Slave_SQL_Running: Yes

两项都显示Yes时说明从202同步数据成功。

至此201202互为主从设置成功!

 

可以试试在这两台服务器上任何一台增加一个数据库,并建个表,增加一些数据看看,互为主从同步的状态是否成功!

首先在201上面:

MariaDB [(none)]> create database mysqltest;

MariaDB [(none)]> use mysqltest;

MariaDB [mysqltest]> create table user(id int(5),name char(10));

MariaDB [mysqltest]> insert into user values (00001,'zhangsan');

202上面验证一下:

MariaDB [(none)]> use mysqltest;

MariaDB [mysqltest]> select * from user;

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

会发现201上面的数据已经自动同步到202上面了

同样在202上面:

MariaDB [mysqltest]> insert into user values (00002,'wander');

 

201上面验证一下:

MariaDB [mysqltest]> select * from user;

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

互为主从结构设置完毕

 

注意:如果同步不成功,首先要确保服务器3306端口打开的。

centos可以用service iptables stop关闭防火墙。

 

八、利用keepalived实现高可用

 

keepalived实现虚拟IP,通过keepalived自带的服务监控功能来实现MySQL故障时自动切换;

 

1keepalived设置:

201服务器上面,编辑keeplaived.conf配置文件:

[root@localhost /]# vi /usr/local/keepalived/etc/keepalived/keepalived.conf

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

配置文件内容如下:

! Configuration File for keepalived

global_defs {
   router_id mysql-ha #运行keepalived机器的一个标识
}

vrrp_instance VI_1 {
    state BACKUP #指定那个为master,那个为backup,如果设置了nopreempt这个值不起作用,主备priority大写
    interface eth0 #设置实例绑定的网卡
    virtual_router_id 201  VPID
    priority 100 #优先级,高优先级竞选为master
    advert_int 1 #检查间隔,默认1
    nopreempt #设置为不抢占 注:这个配置只能设置在backup主机上,而且这个主机优先级要比另外一台高,另一台不要设置这个选项
    authentication { #设置认证
        auth_type PASS #认证方式
        auth_pass 123456 #认证密码
    }
    virtual_ipaddress { #设置vip
        192.168.1.200
    }
}

virtual_server 192.168.1.200 3306 {
    delay_loop 2 #健康检查时间间隔
    lb_algo rr #lvs调度算法rr|wrr|lc|wlc|lblc|sh|dh
    lb_kind DR #负载均衡转发规则NAT|DR|RUN
    persistence_timeout 60 #会话保持时间
    protocol TCP #使用的协议
    real_server 192.168.1.201 3306 {
        weight 1 #默认为1,0为失效
        notify_down /usr/local/keepalived/etc/keepalived/mysql.sh  #在检测到server down后执行脚本 notify  up
        TCP_CHECK {
            connect_port 3306  健康检查的端口的端口
            connect_timeout 3 #连接超时时间
            nb_get_retry 2 #重连次数
            delay_before_retry 1 #重连间隔时间
        }
    }
}
~                

          keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

编辑mysql服务停止后的切换脚本:mysql.sh

[root@localhost /]# vi /usr/local/keepalived/etc/keepalived/mysql.sh

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

内容如下:

#!/bin/bash
pkill keepalived

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

chmod 755 mysql.sh

2、启动201上面的keepalived

[root@localhost /]# /usr/local/keepalived/sbin/keepalived -f /usr/local/keepalived/etc/keepalived/keepalived.conf -D

 

(此处 是使用 刚配好的配置文件来运行)

查看:

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

启动成功后会有三个keepalived进程

 

此是在任一局域机器上面ping 192.168.1.200发现已经可以ping通,并且用192.168.1.200这个IP也能够连接到数据库服务器。

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

3、在202机器上面重复12步骤;

配置keepalived.conf文件的时候注意要把 

real_server 192.168.1.201 3306改为 real_server 192.168.1.202 3306

virtual_router_id 201 改为virtual_router_id 202

priority 100改为priority 90

去掉nopreempt 

 keepalived  Mariadb(mysql) 实现双主 高可用(HA)

 

 

至此MariaDB+Keepalived双主高可用配置MySQL-HA设置完毕。

可以试着把201上面的mariaDB停止 

[root@localhost /]# service mariamysql stop;

会发现连接192.168.1.200还是可以连接上去的,keepalived会自动切换到202的服务器上面去。这样,当一台数据库服务器发生故障时,另一台服务器可以立即切换过来,保证高可用

 

 

 

 

 

赋连接权限

GRANT ALL PRIVILEGES ON *.* to 'root'@'%' identified by '123456';

flush privileges;

 

 

常用操作命令

启动keepalived

/usr/local/keepalived/sbin/keepalived -f /usr/local/keepalived/etc/keepalived/keepalived.conf -D

登录非全局  密码为空

/usr/local/mariamysql/bin/mysql -uroot -p

启动

service mariamysql start