mysql集群高可用配置安装

 

Centos5.5下部署高可用mysql集群
###################### ##mysql高可用集群配置###############################
管理节点(HA主节点):192.168.1.31
数据节点(HA从节点)1:192.168.1.32
数据节点1: 192.168.1.33
数据节点2: 192.168.1.39
SQL节点:192.168.1.32 192.168.1.33 192.168.1.39
VIP:192.168.1.35
eth0:0:192.168.1.35 (31,32) lo:0:192.168.1.33,39
eth0:192.168.1.31 192.168.1.32
eth2:10.1.1.1 10.1.1.2 心跳线(交叉线)
###########################################################################
一、             在192.168.1.31修改/etc/hosts加入以下内容
10.1.1.1      dbManagerha1
10.1.1.2      dbManagerha2
192.168.1.31  localhost
在192.168.1.31修改/etc/hosts
10.1.1.1      dbManagerha1
10.1.1.2      dbManagerha2
192.168.1.32  localhost
二、管理节点安装及其配置
tar -xzvf mysql-cluster-gpl-7.1.5-linux-i686-glibc23.tar.gz ##当前目录为/data
mv mysql-cluster-gpl-7.1.5-linux-i686-glibc23 mysql        
chown -R mysql:mysql mysql
cd mysql
scripts/mysql_install_db --user=mysql                    
chown -R root .
chown -R mysql data
chgrp -R mysql .
bin/mysqld_safe --user=mysql &
mkdir -p /data/mysql/mysql-cluster
mkdir -p /usr/local/mysql/mysql-cluster ##没有此操作后续启动管理节点会出错
vim /data/mysql/mysql-cluster/config.ini #配置管理节点参数,添加如下参数
 
# Options affecting ndbd processes on all data nodes:
[NDBD DEFAULT]
NoOfReplicas=2 # Number of replicas
DataMemory=80M    # How much memory to allocate for data storage
IndexMemory=18M   # How much memory to allocate for index storage
# TCP/IP options:
[TCP DEFAULT]
portnumber=1186  
 
# Management process options:
[NDB_MGMD]
Id=1
hostname=192.168.1.31           # Hostname or IP address of MGM node
datadir=/data/mysql/mysql-cluster # Directory for MGM node logfiles
# Options for data node "A":
[NDBD]
Id=2                           # (one [NDBD] section per data node)
hostname=192.168.1.32           # Hostname or IP address
datadir=/data/mysql/data         # Directory for this data node's datafiles
# Options for data node "B":
[NDBD]
Id=3
hostname=192.168.1.33           # Hostname or IP address
datadir=/data/mysql/data         # Directory for this data node's datafiles
[NDBD]
Id=4
hostname=192.168.1.39           # Hostname or IP address
datadir=/data/mysql/data         # Directory for this data node's datafiles
################################SQL####################################
# SQL node options:
[MYSQLD]
Id=5
hostname=192.168.1.32           # Hostname or IP address
[MYSQLD]
Id=6
hostname=192.168.1.33           # Hostname or IP address
[MYSQLD]
Id=7
hostname=192.168.1.39
[MYSQLD]
[MYSQLD]
三、数据节点安装及其配置
tar -xzvf mysql-cluster-gpl-7.1.5-linux-i686-glibc23.tar.gz
mv mysql-cluster-gpl-7.1.5-linux-i686-glibc23 mysql
chown -R mysql:mysql mysql
cd mysql
scripts/mysql_install_db --user=mysql       此步很重要
cp support-files/my-huge.cnf /etc/my.cnf              
cp support-files/mysql.server /etc/init.d/    #需先修改mysql.server basedir=/data/mysql和
datadir=/data/mysql/datavi /etc/my.cnf 加入如下:
default-storage-engine=ndbcluster 在[mysqld]中加入
 
末端加入:
# Options for mysqld process:
[MYSQLD]
ndbcluster                      # run NDB engine
ndb-connectstring=192.168.1.31 # location of MGM node
# Options for ndbd process:
[MYSQL_CLUSTER]
ndb-connectstring=192.168.1.31 # location of MGM node
四、启动服务
/data/mysql/bin/ndb_mgmd -f /data/mysql/mysql-cluster/config.ini #管理节点操作,启动
/data/mysql/bin/ndb_mgm                   #管理节点查询各节点信息可用show
ndb_mgm> show
Cluster Configuration
---------------------
[ndbd(NDB)]     4 node(s)
id=2    @192.168.1.32 (mysql-5.1.47 ndb-7.1.5, Nodegroup: 0, Master)
id=3    @192.168.1.39 (mysql-5.1.47 ndb-7.1.5, Nodegroup: 0)
id=4    @192.168.1.33 (mysql-5.1.47 ndb-7.1.5, no nodegroup)
[ndb_mgmd(MGM)] 1 node(s)
id=1    @192.168.1.31 (mysql-5.1.47 ndb-7.1.5)
[mysqld(API)]   5 node(s)
id=6    @192.168.1.32 (mysql-5.1.47 ndb-7.1.5)
id=7    @192.168.1.33 (mysql-5.1.47 ndb-7.1.5)
id=8    @192.168.1.39 (mysql-5.1.47 ndb-7.1.5)
id=9 (not connected, accepting connect from any host)
id=10 (not connected, accepting connect from any host)
ndb_mgm> 1 stop #1为管理节点id,添加节点后需要先停止管理节点在,在启动管理节点。
/data/mysql/bin/ndb_mgm -e shutdown                  #安全关闭管理节点
/data/mysql/bin/ndbd --initial               #首次数据节点、sql节点操作用此操作
/data/mysql/bin/ndbd                     #非首次启动数据节点、sql节点
chkconfig --add mysqld                      #数据节点、sql节点操作
chkconfig mysqld on                        #数据节点、sql节点操作
service mysqld start                        #数据节点、sql节点操作
五、测试创建、插入、删除
1、192.168.1.32 上创建数据库create database ftuantestcreate database ftuantest1;后,在192.168.1.39上show databases;
2、删除数据库drop database ftuantest;
六、heartbeat、ipvsadm、ldirectord 高可用安装部署及其配置
1、软件安装                                  
groupadd haclient
useradd -g haclient hacluster
 
yum install libnet*
yum install heartbeat*
yum install perl-DBD-MySQL*
cp /usr/share/doc/heartbeat-2.1.3/ha.cf /etc/ha.d/    
cp /usr/share/doc/heartbeat-2.1.3/authkeys /etc/ha.d/
cp /usr/share/doc/heartbeat-2.1.3/haresources /etc/ha.d/
cp /usr/share/doc/heartbeat-ldirectord-2.1.3/ldirectord.cf /etc/ha.d/
2、配置dbManagerha1
配置网卡:eth0:0
vim /etc/sysconfig/network-scripts/ifcfg-eth0:0
DEVICE=eth0:0
BOOTPROTO=static
BROADCAST=192.168.1.255
HWADDR=00:0c:29:b5:50:a0
IPADDR=192.168.1.35
NETMASK=255.255.255.255
NETWORK=192.168.1.0
ONBOOT=yes
GATEWAY=192.168.1.1
TYPE=Ethernet
配置/etc/ha.dha.cf
debugfile /var/log/ha-debug
logfile /var/log/ha-log
logfacility     local0
keepalive 2
deadtime 30
warntime 10
initdead 120
udpport 694
bcast   eth2
ucast eth2 10.1.1.2
auto_failback on
node    dbManagerha1
node    dbManagerha2
ping 10.1.1.2
respawn hacluster /usr/lib/heartbeat/ipfail
apiauth ipfail gid=haclient uid=hacluster
 
配置:vim/etc/ha.d/authkeys
auth 1
1 crc
#2 sha1 HI!
#3 md5 Hello!
chmod 600 /etc/ha.d/authkeys
配置:vim /etc/ha.d/haresources
dbManager IPaddr::192.168.1.35/24/eth0:0 ipvsadm  ldirectord 末端加入
heartbeat配置完成,接着配置ldirectord
配置:vim /etc/ha.d/ldirectord.cf
checktimeout=3
checkinterval=1
quiescent=yes
virtual = 192.168.1.35:3306
real=192.168.1.33:3306 gate 1
real=192.168.1.39:3306 gate 1
service=mysql
scheduler=wrr
# persistent=600
 protocol=tcp
 checkport=3306
#checktype=negotiate
 checktype=connect
 login="client"
 passwd="123456"
 database="mysql"
 request="SELECT * FROM user"
 
打开ip转发功能
修改/etc/sysctl.conf文件中的
# Controls IP packet forwarding
net.ipv4.ip_forward = 1
在shell环境下执行
sysctl -p
设置ipvsadm转发
/sbin/ipvsadm --set 30 5 60 #分别为协议tcp tcpfin udp 的超时时间
#/sbin/ifconfig eth0:0 $MySQL_VIP broadcast $MySQL_VIP netmask 255.255.255.255 broadcast $MySQL_VIP up #新建VIP
/sbin/ifconfig eth0:0 192.168.1.35 broadcast 192.168.1.35 netmask 255.255.255.255 broadcast 192.168.1.35 up
#/sbin/route add -host 192.168.1.35 dev eth0:0
/sbin/route add -host 192.168.1.35 dev eth0:0 #为VIP添加路由
#/sbin/ipvsadm -A -t 192.168.1.35:3306 -s wlc -p 3 #添加一个VIP
ipvsadm -C
ipvsadm -A -t 192.168.1.35:3306 -s wrr
ipvsadm -a -t 192.168.1.35:3306 -r 192.168.1.33:3306 -g
#将VIP:3306的请求转发到RIP1,-g表示使用DR模式,-w表示权重为1
ipvsadm -a -t 192.168.1.35:3306 -r 192.168.1.39:3306 -g
ipvsadm -Ln   
service ipvsadm start或者/etc/ini t.d/ipvsadm start
3、配置dbManagerha2
把以下所有文件dbManagerha1拷到dbManagerha2
rsync –av  [email protected]:/etc/ha.d/* /etc/ha.d/
scp /etc/sysconfig/ipvsadm 192.168.1.32:/etc/sysconfig/
然后注意备份节点的ha.cf文件在dbManagerha2上把ha.cf中的
ucast eth2 10.1.1.1
4、配置真实机屏蔽ARP广播
/sbin/route add -host 192.168.1.35 dev lo:0
echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
或者在/etc/sysctl.conf里加
net.ipv4.ip_forward = 1
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.lo.arp_announce = 2
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
net.ipv4.conf.default.rp_filter = 1
5、真实机设置回环子接口
vim /etc/sysconfig/network-scripts/ifcfg-lo:0
DEVICE=lo:0
IPADDR=192.168.1.35
NETMASK=255.255.255.255
NAME=loopback
TYPE=Ethernet
GATEWAY=192.168.1.1
service network restart
七、验证步骤
1、验证主从
inet addr:192.168.1.32 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::7ae7:d1ff:fee8:3e5e/64 Scope:Link
inet addr:192.168.1.35 Bcast:192.168.1.255 Mask:255.255.255.0
inet addr:10.1.1.2 Bcast:10.1.1.255 Mask:255.255.255.0
inet6 addr: fe80::7ae7:d1ff:fee8:3e62/64 Scope:Link
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
可以确认到 192.168.1.35 已经存在。从别的服务器也能ping通
2、确认 LVS中设定的列表:
#watch ipvsadm –Ln
 
Every 2.0s: ipvsadm -Ln                                                                                                                         Sat Oct 9 17:33:27 2010
 
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
 -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP 192.168.1.35:3306 wrr
 -> 192.168.1.39:3306            Route   1      0          0
 -> 192.168.1.33:3306            Route   1      0          0
3、确认转发成功
mysql -uclient -p -h 192.168.1.35
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.1.47-ndb-7.1.5-cluster-gpl-log MySQL Cluster Server (GPL)
 
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
mysql>
 
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
 -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP 192.168.1.35:3306 wrr
 -> 192.168.1.39:3306            Route   1      0          0
 -> 192.168.1.33:3306            Route   1      1          0

 

你可能感兴趣的:(数据库,mysql,职场,mysql集群,休闲)