书接上文http://wangfeng7399.blog.51cto.com/3518031/1397530,本文对MariaDB和LVS做高可用集群
一、对MariaDB做高可用集群
1.环境规划
我们通过192.168.1.231对外提供MariaDB提供服务,两个客户端的ip地址分别为192.168.1.200和192.168.1.201,在192.168.1.204上提供了nfs服务为两台数据库提供共享存储
2.准备共享目录
1
|
/data
192.168
.
1.0
/
24
(rw,no_root_squash)
|
3.在创建用户使其能够uid相同
1
2
|
[root@php ~]# groupadd -r -g
306
mysql
[root@php ~]# useradd -r -g mysql -u
306
mysql
|
4.数据库初始化
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
[root@node1 mysql]# groupadd -r -g
306
mysql
[root@node1 mysql]# useradd -r -g mysql -u
306
mysql
[root@node1 ~]# mount -t nfs
192.168
.
1.202
:/data /mydata
[root@node1 ~]# mkdir /mydata/{data,log}
[root@node1 mysql]# chown mysql.mysql /mydata/ -R
[root@node1 ~]# tar xf mariadb-
10.0
.
10
-linux-x86_64.tar.gz -C /usr/local/
[root@node1 ~]# cd /usr/local/
[root@node1 local]# ln -s mariadb-
10.0
.
10
-linux-x86_64 mysql
[root@node1 local]# cd mysql/
[root@node1 mysql]# chown mysql.root * -R
[root@node1 mysql]# cp support-files/my-large.cnf /etc/my.cnf
并修改配置文件
thread_concurrency =
4
datadir=/mydata/data
log-bin=/mydata/logs/mysql-bin
innodb_file_per_table = ON
[root@node1 mysql]# cp support-files/mysql.server /etc/init.d/mysqld
[root@node1 mysql]# chmod +x /etc/init.d/mysqld
初始化数据库
[root@node1 mysql]# scripts/mysql_install_db --user=mysql --datadir=/mydata/data/
|
切记:现在就不需要在节点2上初始化数据了,节点2上的配置文件要跟节点1上保持一致
5.配置权限
1
2
|
MariaDB[none]> grant all on *.* to
'wangfeng7399'
@
'192.168.1.231'
identified by
'wangfeng7399'
;
MariaDB[none]> flush privileges;
|
6.配置集群
添加一个mariadbservice的组,用来存放关于mariadb定义的资源
7测试
先创建一个数据库
此处我们将node2节点关掉
在node1上登陆查看
也可以看到我们创建的数据库
二、对LVS做高可用集群
1.环境规划
我们通过192.168.1.232对外提供LVS提供服务,两台DS的地址分别为192.168.1.200和192.168.1.201,两个RealServer的ip地址分别为192.168.1.204和192.168.1.202
2.在RealServer上配置LVS的服务,两台的配置方法相同
1
2
3
4
5
6
7
8
|
[root@php ~]# echo
1
> /proc/sys/net/ipv4/conf/all/arp_ignore
[root@php ~]# echo
1
> /proc/sys/net/ipv4/conf/eth0/arp_ignore
[root@php ~]# echo
2
> /proc/sys/net/ipv4/conf/eth0/arp_announce
[root@php ~]# echo
2
> /proc/sys/net/ipv4/conf/all/arp_announce
[root@php ~]# ifconfig lo:
0
192.168
.
1.232
netmask
255.255
.
255.255
broadcast
192.168
.
1.232
up
[root@php ~]# route add -host
192.168
.
1.232
lo:
0
启动httpd服务
[root@php ~]# service httpd start
|
3.在两台DS上安装基于lvs的rpm包,如果不安装官方给的文档,要自己书写配置文档,有点麻烦,ldirectord还会检测RealServer的健康状态
1
2
3
4
|
[root@node1 ha]# yum install -y heartbeat-ldirectord-
2.1
.
4
-
12
.el6.x86_64.rpm
最好是通过yum安装,这样可以解决依赖关系
chkconfig ldirectord off
关闭开机自启动
|
4.准备配置文件
1
|
[root@node1 ha]# cp /usr/share/doc/heartbeat-ldirectord-
2.1
.
4
/ldirectord.cf /etc/ha.d/
|
5.修改配置文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
checktimeout=
3
检查超时时间
checkinterval=
1
每个多长时间检测一次心跳
fallback=
127.0
.
0.1
:
80
如果都失败了,会转移到被本机的web服务上
autoreload=yes 配置文件会不会自动装载
logfile=
"/var/log/ldirectord.log"
日志文件
#logfile=
"local0"
或者使用syslog
#emailalert=
"admin@x.y.z"
#emailalertfreq=
3600
#emailalertstatus=all
quiescent=yes 是否使用静默模式
virtual=
192.168
.
1.232
:
80
定义VIP与端口
real=
192.168
.
1.204
:
80
gate RealServer的ip地址 gate表示DR
real=
192.168
.
1.202
:
80
gate
fallback=
127.0
.
0.1
:
80
gate 如果所有的检查失败,使用的页面
service=http 基于那种方式做监控检查
request=
".health.html"
监控检查的文件
receive=
"wangfeng7399"
检查的内容
scheduler=rr 调度算法
#persistent=
600
定义持久连接时间
netmask=
255.255
.
255.255
定义子网掩码
|
说明:定义时,只能virtual顶个写,其余的都要空一个制表符,要不会出现语法错误
6.在各Real Server上添加.health.html内容为wangfeng7399
7.在DS上准备一个错误页面,内容为“维护时间”,并启动web服务
8.配置服务
9.测试
通过ipvsadm查看
通过网页查看
我们将web1关掉,依次来模拟一台Real Server 坏掉
我们将两台服务器都关掉
通过web查看,为我们在DS上定义的页面
我们启动其中任何一台,在查看
都不会再看到我们定义的维护页面
大功告成,由于本人水平有限,可能会有错误,请各位大神批评指正