一、总概:

本文介绍了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/MySQL-5.6/MySQL-5.6.17-1.el6.x86_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)、已有数据库的存在

[root@localhost 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不可以相同!

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

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

    一.总概 1.MHA介绍 MHA(Master High Availability)是自动的master故障转移和Slave提升的软件包.它是基于标准的MySQL复制(异步/半同步).      MH ...

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

    一.概述 keepalived介绍:Keepalived的作用是检测web服务器的状态,如果有一台web服务器死机,或工作出现故障,Keepalived将检测到,并将有故障的web 服务器从系统中剔除 ...

  3. MySQL数据库MHA+keepalive实现

    MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshimaton(现就职于Facebook公司)开发,是一套优秀 ...

  4. 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 ...

  5. mysql mha高可用架构的安装

    MMM无法全然地保证数据的一致性,所以MMM适用于对数据的一致性要求不是非常高.可是又想最大程度的保证业务可用性的场景对于那些对数据一致性要求非常高的业务,非常不建议採用MMM的这样的高可用性架构.那 ...

  6. MySQL MHA配置常见问题

    MHA在MySQL数据库中被广泛使用,它小巧易用,功能强大,实现了基于MySQL replication架构的自手动主从故障转移,从库重定向到主库并自动同步.尽管如此,在部署配置的过程中,由于疏忽总难 ...

  7. MySQL MHA配置

    MySQL环境: master:192.168.202.129:3306 slave:192.168.202.129:3307,192.168.202.129:3307,192.168.202.130 ...

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

    本例中mysql的安装方式选用了二进制包安装方案.mysql复制用半同步复制方案 [1]安装mysql-5.6.31 要在所有的数据节点上都安装上mysql,安装方式大致相同,所以我这里就不重复写多次 ...

  9. centos7 mysql+MHA高可用安装

    https://dzone.com/articles/consul-proxysql-and-mysql-ha?utm_medium=feed&utm_source=feedpress.me& ...

随机推荐

  1. Lucene、ES好文章

    1.lucene4.5源码分析系列:lucene概述 http://blog.csdn.net/liweisnake/article/details/10348969 http://www.cnblo ...

  2. DataGridView控件-[引用]

    DataGridView控件 DataGridView是用于Windows Froms 2.0的新网格控件.它可以取代先前版本中DataGrid控件,它易于使用并高度可定制,支持很多我们的用户需要的特 ...

  3. BZOJ.2834.回家的路(最短路Dijkstra 拆点)

    题目链接 对于相邻的.处在同在一行或一列的车站连边,然后用dis[x][0/1](或者拆点)分别表示之前是从横边还是竖边到x的,跑最短路. 我选择拆点.. //13028kb 604ms #inclu ...

  4. COGS.1901.[模板][国家集训队2011]数颜色(带修改莫队)

    题目链接 COGS BZOJ2120 洛谷P1903 /* Add和Subd函数中的vis不能直接设为=1或=0 比如 l=1,r=0 -> l=3,r=5 时,[1,5]的vis标记全都是1 ...

  5. ssm中从页面到controller和数据库出现乱码问题的解决

    1.确保项目编码为utf8,点击项目右键,点击properties 2.确保数据库编码为utf8,以MySQL为例,可到mysql目录下,my.ini文件中修改后,重启mysql服务 重启mysql服 ...

  6. JDBC(5)—DatabaseMetaData

    1.简介: 使用元数据已实现通用的查询方法.元数据介绍:使用jdbc获得连接之后,得到一个Connection对象,可以通过这个对象获得DataBaseMetaData对象,该对象可以获得有关数据库管 ...

  7. Object类--equals方法

    equals方法 1.比较的是对象引用的是否指向同一块内存地址 public static void main(String[] args) { HuaWei huawei=new HuaWei(); ...

  8. linux tomcat 绑定域名

    1.解析域名到对应的服务器ip 2.找到tomcat安装路径进入/conf 3.vi server.xml 4.修改<Connector port="8080" protoc ...

  9. Cassandra的数据模型的理解

           Cassandra属于NoSQL数据库,NoSQL和传统关系型数据库不同,NOSQL偏好数据冗余,因为NoSQL一般无法做表关联查询. (1) keySpace 基本上可以将Keyspa ...

  10. 你还记得当初为什么进入IT行业吗?

    说到这个问题,小编相信不少童鞋开始忆往昔峥嵘岁月,那个少年为了心中的改变世界的理想,进入了这个行业,但是呢,有一群人画风就不一样了,他们进入IT行业,完全只是是因为.... 小时候广告看多了....: ...