HA专题: 使用pacemaker+corosync实现MySQL高可用

HA专题: 使用pacemaker+corosync实现MySQL高可用

前言

上篇文章我们介绍了使用pacemkaer+corosync实现简单的nginx高可用, 这篇文章我们介绍如何使用pacemaker+corosync实现MySQL高可用, 并且此次我们手动编辑配置文件来实现corosync的配置

实验拓扑

Alt textblob.png

实验环境

主机 IP 功用
node1.anyisalin.com 172.16.1.2 MySQL服务, HA节点
node2.anyisalin.com 172.16.1.3 MySQL服务, HA节点
nfs.anyisalin.com 172.16.1.4 提供nfs服务,数据库文件

注意: 本文实验中所有主机SElinux和iptables都是关闭的

实验步骤

准备工作

高可用集群必须保证所有节点主机互信, 主机名解析一致, 时间同步

配置hosts文件同步
Alt textblob.png

配置互信
Alt text

Alt textblob.png

blob.png

时间同步
blob.pngAlt text

安装HA组件并配置

我们这次直接安装并手动配置pacemaker+corosync

安装corosync+pacemaker在两个节点上

[root@node1 ~]# yum install corosync pacemaker -y &> /dev/null && echo success
success
[root@node1 ~]# ssh node2.anyisalin.com "yum install corosync pacemaker -y &> /dev/null && echo success"
success

编辑配置文件

[root@node1 corosync]# vim corosync.conf

        totem {
            version: 2
        crypto_cipher: none
        crypto_hash: none


            interface {
                ringnumber: 0
                bindnetaddr: 172.16.1.0
                mcastaddr: 239.185.1.31
                mcastport: 5405
                ttl: 1
            }
        }

        nodelist { 
                node {
                        ring0_addr: 172.16.1.2
                        nodeid: 1
                }
                node {
                        ring0_addr: 172.16.1.3
                        nodeid: 2
                }
        }

        logging {
            fileline: off
            to_stderr: no
            to_logfile: yes
            logfile: /var/log/cluster/corosync.log
            to_syslog: no
            debug: off
            timestamp: on
            logger_subsys {
                subsys: QUORUM
                debug: off
            }
        }

        quorum {
            provider: corosync_votequorum
        }

启动corosync和pacemaker

[root@node1 corosync]# scp corosync.conf node2.anyisalin.com:/etc/corosync/
[root@node1 corosync]# systemctl start corosync pacemkaer
[root@node1 corosync]# ssh node2.anyisalin.com "systemctl start corosync pacemkaer"

查看集群节点状态

[root@node1 corosync]# crm status   #各节点都在线
Last updated: Sun Apr 10 22:23:13 2016      Last change: Sun Apr 10 22:16:43 2016 by root via cibadmin on node1.anyisalin.com
Stack: corosync
Current DC: node1.anyisalin.com (version 1.1.13-10.el7_2.2-44eb2dd) - partition with quorum
2 nodes and 0 resources configured

Online: [ node1.anyisalin.com node2.anyisalin.com ]

配置NFS

对于NFS配置这次比较复杂

[root@nfs ~]# vim /etc/exports
/datadir    172.16.1.0/24(rw,no_root_squash)

[root@nfs ~]# useradd -u 3306 mysql  #创建mysql用户

[root@nfs ~]# mkdir /datadir
[root@nfs ~]# setfacl -m u:mysql:rwx /datadir/  #赋予mysql用户权限

[root@nfs ~]# exportfs -rv   #重新导出目录
exporting 172.16.1.0/24:/datadir

配置MySQL

MySQL我们使用通用二进制的包安装, 安装过程有疑问的可以看我以前的LAMP安装的文章

在node1上操作

[root@node1 corosync]# tar xf mysql-5.5.33-linux2.6-x86_64.tar.gz -C /usr/src/
[root@node1 corosync]# cd /usr/src/mysql-5.5.33-linux2.6-x86_64/
[root@node1 mysql-5.5.33-linux2.6-x86_64]# groupadd -g 3306 -r mysql
[root@node1 mysql-5.5.33-linux2.6-x86_64]# useradd -u 3306 -g mysql mysql
[root@node1 mysql-5.5.33-linux2.6-x86_64]# mkdir /datadir
[root@node1 mysql-5.5.33-linux2.6-x86_64]# mount -t nfs 172.16.1.4:/datadir /datadir/ #挂载nfs到本地

[root@node1 mysql-5.5.33-linux2.6-x86_64]# ./scripts/mysql_install_db --user=mysql --datadir=/datadir #初始化MySQL生成数据库文件
[root@node1 mysql-5.5.33-linux2.6-x86_64]# ls /datadir/
mysql  performance_schema  test

[root@node1 mysql-5.5.33-linux2.6-x86_64]# cp support-files/my-large.cnf /etc/my.cnf 
[root@node1 mysql-5.5.33-linux2.6-x86_64]# vim /etc/my.cnf #添加以下几行
datadir=/datadir
innodb_file_per_table = on
skip_name_resolve = on
[root@node1 mysql-5.5.33-linux2.6-x86_64]# cp support-files/mysql.server /etc/init.d/mysqld
[root@node1 mysql-5.5.33-linux2.6-x86_64]# cd /usr/local/
[root@node1 local]# ln -sv /usr/src/mysql-5.5.33-linux2.6-x86_64/ mysql  #创建软链接
[root@node1 ~]# service mysqld start  #启动mysql
Starting MySQL.. SUCCESS! 
[root@node1 ~]# /usr/local/mysql/bin/mysql  #登录成功
mysql> 


在node2上操作
[root@node2 ~]# tar xf mysql-5.5.33-linux2.6-x86_64.tar.gz  -C /usr/src/
[root@node2 ~]# mkdir /datadir
[root@node2 ~]# mount -t nfs 172.16.1.4:/datadir /datadir/
[root@node2 ~]# ls /datadir/
ibdata1  ib_logfile0  ib_logfile1  mysql  mysql-bin.000001  mysql-bin.000002  mysql-bin.index  node1.anyisalin.com.err  node1.anyisalin.com.pid  performance_schema  test

[root@node2 ~]# scp node1.anyisalin.com:/etc/my.cnf /etc/
[root@node2 ~]# scp node1.anyisalin.com:/etc/init.d/mysqld /etc/init.d/


[root@node2 ~]# cd /usr/local/
[root@node2 local]# groupadd -g 3306 -r mysql
[root@node2 local]# useradd -g mysql -u  3306 mysql
[root@node2 local]# ln -sv /usr/src/mysql-5.5.33-linux2.6-x86_64/ mysql
‘mysql’ -> ‘/usr/src/mysql-5.5.33-linux2.6-x86_64/’

[root@node2 ~]# service mysqld start #因为node1在运行所以不能运行
Starting MySQL........
[root@node2 ~]# ssh node1.anyisalin.com "service mysqld stop"

[root@node2 local]# service mysqld start  #启动成功
Starting MySQL SUCCESS!
[root@node2 local]# /usr/local/mysql/bin/mysql  #能够登录

mysql> 


#测试完成后将mysql服务停止并卸载nfs
[root@node2 local]# service mysqld stop
Shutting down MySQL. SUCCESS! 
[root@node2 local]# umount /datadir/
[root@node1 ~]# umount /datadir/

配置HA资源

crm(live)# configure
crm(live)configure# primitive dataip ocf:heartbeat:IPaddr params ip=172.16.1.8
crm(live)configure# primitive datastore ocf:heartbeat:Filesystem params device="172.16.1.4:/datadir" fstype="nfs" directory="/datadir" 
crm(live)configure# primitive mysql service:mysqld  
crm(live)configure# property stonith-enabled=false
colocation dataip_with_datastore inf: mysql ( dataip datastore ) #设置排列约束
order dataip_then_webstore Mandatory: dataip datastore  #设置顺序约束
order datastore_then_mysql Mandatory: datastore mysql
crm(live)configure# commit

测试

Alt textblob.png

blob.png

Alt text

Alt textblob.png

blob.png

blob.png

Alt text

Alt text

总结

这样我们就能实现一个MySQL HA集群了, 但是NFS是个单点故障. 如果NFS的数据挂了怎么办? 很快我们就会写drbd实现MySQL高可用了. 本系列文章主要侧重于实验. 对理论知识不做阐述, 还请多多谅解

作者水平很低, 如果有错误及时指出, 如果你觉得本文写的好请点一波赞~(≧▽≦)/~
作者: AnyISaIln QQ: 1449472454
感谢: MageEdu

原创文章,作者:Net18-AnyISalIn,如若转载,请注明出处:http://www.178linux.com/14645

(2)
Net18-AnyISalInNet18-AnyISalIn
上一篇 2016-04-11
下一篇 2016-04-11

相关推荐

  • 计算机组成、Linux命令基础

    计算机组成 控制器(Control):是整个计算机的中枢神经,其功能是对程序规定的控制信息进行解释,根据其要求进行控制,调度程序、数据、地址,协调计算机各部分工作及内存与外设的访问等。 运算器(Datapath):运算器的功能是对数据进行各种算术运算和逻辑运算,即对数据进行加工处理。 存储器(Memory):存储器的功能是存储程序、数据和各种信号、命令等信息…

    Linux干货 2016-09-19
  • sudo——让普通用户更灵活

    sudo命令 1、sudo能够授权指定用户在指定主机上运行某些命令。如果未授权用户尝试使用sudo ,会提示联系管理员 2、sudo可以提供日志,记录每个用户使用sudo 操作 3、sudo为系统管理员提供配置文件,允许系统管理员集中地管理用户的使用权限和使用的主机 4、sudo 使用时间戳文件来完成类似“检票”的 系统,默认存活期为5 分钟的 “入场券” …

    Linux干货 2016-09-25
  • Linux文件目录的权限

     Linux是多用户多任务的分时操作系统,如果每个人都对文件和目录都是随便访问的话,难么你的文件很有可能会被他人删除或修改,从而丢失数据。为此系统对文件增加了权限的机制来防止这种事情的发生。对文件而言,用户被分为三类:属主(onwer)、属组(group)、和其他(other)。常规的权限分为:读(r readable)、写(w writable)…

    Linux干货 2016-08-07
  • 文本处理-vim编辑器

    命令格式、(1)模式、(2)关闭文件、(3)可视化模式、(4)使用多个“窗口”、(5)定制vim的工作特性、(6)示例

    2018-03-13
  • vsphere虚拟机下的Linux在线移除硬盘后的报错处理(基于LVM)

    1)故障描述( vmware虚拟机,在线移除一块被设置为pv格式的硬盘后,提示unknown device错误): 说明:/dev/sdb1 /dev/sdc1 /dev/sdd1是组成/dev/vg_test/lvm_test的PV,这里我们模拟/dev/sdd1硬盘被直接断电了 [root@docker mnt]# pvdisplay…

    Linux干货 2016-07-29
  • 分布式系统介绍及MogileFS安装、基本配置

    分布式系统介绍及MogileFS安装、基本配置 分布式 MogileFS 前言: 什么是分布式? 分布式存在的意义? 分布式的难点及CAP、BASE、2PC、X/Open XA介绍 分布式存储和分布式文件系统: MogileFS实现原理: MogileFS编译安装和配置 总结 前言: 不知不觉中我们就进入大数据时代, 什么是大数据? 什么是分布式?…

    Linux干货 2016-05-04

评论列表(2条)

  • Net18-天津-康康
    Net18-天津-康康 2016-04-11 13:48

    这些链接是怎么实现的,博客有这个功能么