Linux运维 第五阶段(三)mysql高可用(基于heartbeat、nfs)

Linux运维 第五阶段(三)mysql高可用(基于heartbeatnfs

 

一、相关注意事项:

基于heartbeatV2crm)和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输出时的UIDGIDmysql访问数据,都要是mysql用户,mysql组,要对相应目录有读写权限,而且此例中有两个node,这两个nodemysql用户和组的UIDGID最好一样,若不一样就得配置nfs在输出时文件属性中要有这两个nodeUIDGID

 

mysql数据最好放在LVM上,既方便扩展又方便备份,LVM应在nfs所属的服务器上创建

 

二、操作:

wKiom1ZiNbzxp9ExAAA9NVBeyI0640.jpg

注:在同一时刻,node1node2仅一台提供服务,若当前提供服务的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-->添加如图ipniccidr_netmask

add new item:-->native-->resourceID:mysqlstore-->filesystem-->添加如图devicedirectoryfstype

add new item:-->native-->resourceID:mysqld-->mysqld

wKiom1ZiNdXSZXUdAACV_nkor2E691.jpg

wKioL1ZiNkGR3ic6AACYdBnVk_U607.jpg


在组上右键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;

在图形界面的窗口上,右键node2standby,在node3上再试登录mysql看是否正常

wKioL1ZiNn3hf4ZVAACR-whDPZ0462.jpg

 

 

 

以上是学习《马哥运维课程》做的笔记。


本文出自 “Linux运维重难点学习笔记” 博客,谢绝转载!

你可能感兴趣的:(linux运维)