一、相关注意事项:
基于heartbeatV2(crm)和nfs共享实现mysql高可用集群(关键点:如果是一主一从两个node,主若挂掉,从可以取而代之,并且主node上的数据,从node可以访问到;此种架构并不理想,nfs-server易成为单点故障,若再对nfs做高可用共享存储要用iscsi,这时至少要4台设备,再者如果有iscsi设备就可直接使用,不用再中间夹个nfs)
本例中在NFS共享存储中仅是mysql数据目录,两个node均在本地有mysql程序和配置文件(若NFS上存放mysql程序、mysql数据及配置文件,如何实现让mysql到共享存储上读配置文件?使用选项指定)
注:mysql读取配置文件的先后次序:/etc/my.cnf-->/etc/mysql/my.cnf-->$MYSQL_HOME/my.cnf-->--default-extra-file=/PATH/TO/FILE-->~/.my.cnf(让mysqld服务器端程序接受选项(--default-extra-file=/PATH/TO/FILE),同时将前面几处位置的不提供配置文件即可)
OCF格式的RA(可灵活指定很多参数,来配置脚本的工作属性)
LSB格式的RA(脚本固定,内设好的,不能提供参数)此例使用的是LSB格式的脚本
注:corosync中专门为mysql提供了RA,这个RA可接受参数用于告知mysql程序配置文件在哪
注意nfs输出时的UID、GID(mysql访问数据,都要是mysql用户,mysql组,要对相应目录有读写权限,而且此例中有两个node,这两个node的mysql用户和组的UID、GID最好一样,若不一样就得配置nfs在输出时文件属性中要有这两个node的UID、GID)
mysql数据最好放在LVM上,既方便扩展又方便备份,LVM应在nfs所属的服务器上创建
二、操作:
注:在同一时刻,node1和node2仅一台提供服务,若当前提供服务的node1-mysql-server挂掉,另一台node2接替其工作
node3-side:
本例是单独拿出一块磁盘制作LVM
#fdisk /dev/sdb(大小+5G,分区类型8e)
#partprobe /dev/sdb
#pvcreate /dev/sdb1
#vgcreate myvg /dev/sdb1
#lvcreate -L 5G -n mydata myvg
#lvs
#mke2fs -j /dev/myvg/mydata
#groupadd -g 3306 mysql
#useradd -u 3306 -g mysql -s /sbin/nologin -M mysql
#mkdir /mydata
#vim /etc/fstab
/dev/myvg/mydata /mydata ext3 defaults 0 0
#mount -a
#mount
#mkdir /mydata/data
#chown -R mysql:mysql /mydata/data
#vim /etc/exports
/mydata/data 192.168.41.129/24(no_root_squash,rw) 192.168.41.130/24(no_root_squash,rw) (此处一定要有no_root_squash,默认生效的是root_squash是将root转为anonymous)
#exportfs -arv
node1-side:
#groupadd -g 3306 mysql
#useradd -u 3306 -g mysql -s /sbin/nologin -M mysql
#mkdir /mydata
#mount -t nfs 192.168.41.128:/mydata /mydata
#usermod -s /bin/bash mysql(测试下mysql用户是否对该目录有写权限)
#su - mysql
#cd /mydata/data
#touch test.txt
#ll
#usermod -s /sbin/nologin mysql
#tar xf mysql-5.5.45-linux2.6-i686.tar.gz -C /usr/local/
#cd /usr/local
#ln -sv mysql-5.5.45-linux2.6-i686/ mysql
#cd mysql
#ll
#chown -R root:mysql ./*
#mount -t nfs 192.168.41.128:/mydata /mydata
#scripts/mysql_install_db --user=mysql --datadir=/mydata/data
#ll /mydata/data
#cp support-files/my-large.cnf /etc/my.cnf
#vim /etc/my.cnf
[mysqld]
datadir = /mydata/data
innodb_file_per_table = 1
#cp support-files/mysql.server /etc/init.d/mysqld
#chkconfig --add mysqld
#chkconfig mysqld off
#chkconfig --list mysqld
#service mysqld start
#/usr/local/mysql/bin/mysql
>SHOW DATABASES;
>CREATE DATABASE mydb;
>SHOW DATABASES;
>GRANT ALL ON *.* TO ‘root’@’%’ IDENTIFIED BY ‘redhat’;
>FLUSH PRIVILEGES;
>\q
#service mysqld stop
#umount /mydata
#scp /etc/init.d/mysqld node2:/etc/init.d/
#scp /etc/my.cnf node2:/etc/
node2-side:
配置与node1-side相同,node2上不用执行初始化,最后查看有无node1创建的mydb库
#hb_gui &
添加如图组和资源:
add new item:-->选group-->ID:mysql-->resourceID:mysqlip-->选IPaddr-->添加如图ip、nic、cidr_netmask
add new item:-->选native-->resourceID:mysqlstore-->选filesystem-->添加如图device、directory、fstype
add new item:-->选native-->resourceID:mysqld-->选mysqld
在组上右键start
测试:
node3-side:
#mysql -u root -p -h192.168.41.222
>SHOW DATABASES;
>USE mydb;
>CREATE TABLE testtb (id int unsigned not null auto_increment primary key,name char(20));
>SHOW TABLES;
在图形界面的窗口上,右键node2点standby,在node3上再试登录mysql看是否正常
本文转自 chaijowin 51CTO博客,原文链接:http://blog.51cto.com/jowin/1719775,如需转载请自行联系原作者