MYSQL + MHA +keepalive + VIP安装配置(一)--MYSQL安装配置

一、总概:

本文介绍了MySQL高可用性的实现方案MHA,MHA由Node和Manager组成,Node运行在每一台MySQL服务器上,不管是MySQL主服务器,还是MySQL从服务器,都要安装Node。主从安装keepalived ,实现虚拟ip漂移,程序不用改IP自动切换。

二、环境

1、操作系统:centos 6.5 64位

2、数据库:   MySQL-5.6.17-1.el6.x86_64.rpm-bundle.tar 下载

3、MHA版本:mha4mysql-node-0.54-0.el6.noarch.rpm,

mha4mysql-manager-0.54-0.el6.noarch.rpm

4、keepalived版本:

5、主机部署:

manager机:192.168.1.201

master机:192.168.1.231

slave1机:192.168.1.232(备用master)

6、大致步骤:

(1)、安装MYSQL 5.6.

(2)、MYSQL配置主重复制.

(3)、首先用ssh-keygen实现四台主机之间相互免密钥登录.

(4)、安装MHAmha4mysql-node,mha4mysql-manager 软件包

(5)、在MHA配置master,slave1的相关文件。

(6)、管理机manager上配置MHA文件

(7)、masterha_check_ssh工具验证ssh信任登录是否成功

(8)、masterha_check_repl工具验证mysql复制是否成功

(9)、启动MHA manager,并监控日志文件.

(10)、测试master宕机后,是否会自动切换。

(11)、主从安装keepalived ,实现虚拟ip漂移。

三、mysql安装

1、下载MYSQL 5.5

wget http://cdn.mysql.com/Downloads/M ... 6_64.rpm-bundle.tar

tar -cf MySQL-5.6.17-1.el6.x86_64.rpm-bundle.tar

2、解压后文件有:

MySQL-client-5.6.17-1.el6.x86_64.rpm

MySQL-devel-5.6.17-1.el6.x86_64.rpm

MySQL-embedded-5.6.17-1.el6.x86_64.rpm

MySQL-server-5.6.17-1.el6.x86_64.rpm

MySQL-shared-5.6.17-1.el6.x86_64.rpm

MySQL-shared-compat-5.6.17-1.el6.x86_64.rpm

MySQL-test-5.6.17-1.el6.x86_64.rpm

注意:其实只要安装,服务器端MySQL-server-5.6.17-1.el6.x86_64.rpm 客户端MySQL-client-5.6.17-1.el6.x86_64.rpm 及MySQL-shared-compat-5.6.17-1.el6.x86_64.rpm(可以解决一些兼容性)

3、安装

rpm -ivh MySQL-client-5.6.17-1.el6.x86_64.rpm

rpm -ivh MySQL-server-5.6.17-1.el6.x86_64.rpm

rpm -ivh MySQL-shared-compat-5.6.17-1.el6.x86_64.rpm

4、可能会报的错:

(1)、已有数据库的存在

[[email protected] local]# rpm -ivh MySQL-server-5.6.17-1.el6.x86_64.rpm

Preparing...                ########################################### [100%]

file /usr/share/mysql/charsets/Index.xml from install of MySQL-server-5.6.17-1.el6.x86_64 conflicts with file from package mysql-libs-5.1.71-1.el6.x86_64

file /usr/share/mysql/charsets/armscii8.xml from install of MySQL-server-5.6.17-1.el6.x86_64 conflicts with file from package mysql-libs-5.1.71-1.el6.x86_64

file /usr/share/mysql/charsets/ascii.xml from install of MySQL-server-5.6.17-1.el6.x86_64 conflicts with file from package mysql-libs-5.1.71-1.el6.x86_64

file /usr/share/mysql/charsets/cp1250.xml from install of MySQL-server-5.6.17-1.el6.x86_64 conflicts with file from package mysql-libs-5.1.71-1.el6.x86_64

说明:系统中已存在mysql-libs-5.1.71-1.el6.x86_64 必须把它卸载掉。解决方法:

yum -y remove mysql-libs-5.1.71*

(2)、缺少一下依赖的组件

error: Failed dependencies:

/usr/bin/perl is needed by MySQL-server-5.6.17-1.el6.x86_64

libaio.so.1()(64bit) is needed by MySQL-server-5.6.17-1.el6.x86_64

libaio.so.1(LIBAIO_0.1)(64bit) is needed by MySQL-server-5.6.17-1.el6.x86_64

libaio.so.1(LIBAIO_0.4)(64bit) is needed by MySQL-server-5.6.17-1.el6.x86_64

解决方法:

yum install perl

yum install libaio

再重新安装,安装成功。默认root 没有密码,端口为:3306.

5、由于是RPM安装的所以在/etc/下没有MYSQL的my.cnf文件。解决方法:

cp /usr/share/mysql/my-medium.cnf  /etc/my.cnf

这样可以修改MYSQL的一些配置文件了。

6、mysql启动、停止、重启。

service mysql start    或  /etc/init.d/mysql start

service mysql stop     或  /etc/init.d/mysql stop

service mysql restart  或  /etc/init.d/mysql restart

7、创建用户,用于主从复制的账号

CREATE USER ‘username‘@‘host‘ IDENTIFIED BY ‘password‘;

username - 你将创建的用户名,

host - 指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost, 如果想让该用户可以从任意远程主机登陆,可以使用通配符%.

password - 该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器.

例如:

CREATE USER ‘sunney‘@‘%‘ IDENTIFIED BY ‘sunney‘;

8、用户授权

grant privileges ON databasename.tablename TO ‘username‘@‘host‘ identified by "password";

例如:

grant all privileges  ON *.* TO ‘sunney‘@‘%‘ identified by "sunney";

FLUSH PRIVILEGES  //修改生效

9、已可以远程访问数据库了。

如上步骤两台主机:231、232都按已上步骤安装MYSQL.

四、建产mysql 主从数据库配置

[master:231]

1.shell>vi /etc/my.cnf

server-id=1

log-bin=mysql-bin

binlog_format=mixed

2.mysql>show master status;

[slave1]

3.change master操作

mysql>change master to

master_host=‘192.168.1.231‘,

master_port=3306,

master_user=‘sunney‘,

master_password=‘sunney‘,

master_log_file=‘mysql-bin.000001‘,

master_log_pos=112;

[master,slave1]

4.查看主从复制是否成功的一些命令

mysql>start slave;

mysql>stop slave;

mysql>reset slave;

mysql>show slave status\G;

5.所有主机上设置复制权限帐号

mysql>GRANT ALL PRIVILEGES ON*.*TO‘sunney‘@‘%‘IDENTIFIED BY ‘sunney‘;

注意:

(1)、master_log_file=‘mysql-bin.000001‘,master_log_pos=112;

这两名是通过maste中用: show master status;查出来的。

(2)、master与slave的server-id 是不能相同,否则不能同步成功。

slave的server-id可以通过修改 /etc/my.cnf或

mysql> set global server_id=2; #此处的数值和my.cnf里设置的一样就行。

五、总结

数据库的安装及master与slave配置成功,可以进行主从同步了!主从同步的常见错误,其实不外乎就是网络、权限、iptables、SELinux等问题,我们平时注意检查这些问题,处理起来应该不是很困难,大家记得关闭iptables(或开通对应的端口)和SELinux,注意Slave_IO_Running和Slave_SQL_Running状态必须确保主Yes才行,另外也要注意从机的Seconds_Behind_Master值及主从机的server-id不可以相同

时间: 2024-10-15 05:31:02

MYSQL + MHA +keepalive + VIP安装配置(一)--MYSQL安装配置的相关文章

MYSQL + MHA +keepalive + VIP安装配置(三)--keepalived安装配置

一.概述 keepalived介绍:Keepalived的作用是检测web服务器的状态,如果有一台web服务器死机,或工作出现故障,Keepalived将检测到,并将有故障的web 服务器从系统中剔除,当web服务器工作正常后Keepalived自动将web服务器加入到服务器群中,这些工作全部自动完成,不需要人工干涉,需要人 工做的只是修复故障的web服务器. 二.环境 ? 1 2 3 vip:192.168.1.203\204 mysql-master:192.168.1.231 mysql-

MYSQL + MHA +keepalive + VIP安装配置(二)--MHA的配置

一.总概 1.MHA介绍 MHA(Master High Availability)是自动的master故障转移和Slave提升的软件包.它是基于标准的MySQL复制(异步/半同步). MHA有两部分组成:MHA Manager(管理节点)和MHA Node(数据节点). MHA Manager可以单独部署在一台独立机器上管理多个master-slave集群,也可以部署在一台slave上.MHA Manager探测集群的node节点,当发现master出现故障的时候,它可以自动将具有最新数据的s

Centos 6.5 安装配置Mysql MHA

MHA是什么?MHA是由日本Mysql专家用Perl写的一套Mysql故障切换方案,来保障数据库的高可用性,它的功能是能在0-30s之内实现主Mysql故障转移(failover),MHA故障转移可以很好的帮我们解决从库数据的一致性问题,同时最大化挽回故障发生后数据的一致性.MHA里有两个角色一个是node节点 一个是manager节点,要实现这个MHA,必须最少要三台数据库服务器,一主多备,即一台充当master,一台充当master的备份机,另外一台是从属机,这里实验为了实现更好的效果使用四

mysql mha高可用性安装配置

Installation bmildren edited this page on 27 Jan 2016        ·        1 revision Pages 30 Home Advantages Architecture CommercialSupport Configuration Downloads FAQ GTID_Based_Failover HowMHAWorks Installation masterha_check_repl masterha_check_statu

mysql mha高可用架构的安装

MMM无法全然地保证数据的一致性,所以MMM适用于对数据的一致性要求不是非常高.可是又想最大程度的保证业务可用性的场景对于那些对数据一致性要求非常高的业务,非常不建议採用MMM的这样的高可用性架构.那么可以考虑使用MHA.在mysql故障切换的过程中.MHA可以在0-30s内自己主动完毕数据库的故障切换操作,而且MHA可以最大程度上保证数据的一致性,以达到真正意义上的高可用. MHA软件由两部分组成,Manager工具包和Node工具包.详细的说明例如以下. Manager工具包主要包含下面几个

Mysql MHA 配置测试使用说明

Mysql MHA 使用说明 一.         MHA 简介 MHA,即Master High Availability Manager and Tools for MySQL,是日本的一位MySQL专家采用Perl语言编写的一个脚本管理工具,该工具仅适用于MySQL Replication(二层)环境,目的在于维持Master主库的高可用性. MHA(Master High Availability)是自动的master故障转移和Slave提升的软件包.它是基于标准的MySQL复制(异步/

Mysql MHA(GTID)配置(实操)

实现环境 centos6.7 MYSQL5.6.36 主:192.168.1.191 从1:192.168.1.145 从2:192.168.1.146 监测:放在从2上 192.168.1.146 虚拟IP:192.168.1.222 准备软件包:下载链接: https://pan.baidu.com/s/1jHYafcU 密码: irbv epel-release-6-8.noarch.rpm   (所有服务器上都要) mha4mysql-node-0.56-0.el6.noarch.rpm

搭建MHA环境【2】安装mysql-5.6 + mysql复制

本例中mysql的安装方式选用了二进制包安装方案.mysql复制用半同步复制方案 [1]安装mysql-5.6.31 要在所有的数据节点上都安装上mysql,安装方式大致相同,所以我这里就不重复写多次了,只以一台为例. 1.1 解压安装包到/usr/local/ tar -xzvf mysql-5.6.31-linux-glibc2.5-x86_64.tar.gz -C /usr/local 1.2 为了创建linux系统的mysql用户 useradd mysql 1.3 创建连接文件 cd

MySQL MHA配置常见问题

MHA在MySQL数据库中被广泛使用,它小巧易用,功能强大,实现了基于MySQL replication架构的自手动主从故障转移,从库重定向到主库并自动同步.尽管如此,在部署配置的过程中,由于疏忽总难以避免这样或那样的错误.本文是对MHA配置中常见问题的一个汇总,供大家参考.http://hovertree.com/menu/mysql/ 1.非root用户等效性环境等效性配置  a.添加所有节点(含管理节点)主机名及IP到host文件,所有节点操作  b.生成基于非root用户(如使用mysq