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


1、总概:node


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


2、环境sql


一、操做系统:centos 6.5 64位shell


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


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


                    mha4mysql-manager-0.54-0.el6.noarch.rpm服务器


四、keepalived版本:网络


五、主机部署:ssh


manager机:192.168.1.201ide

master机:192.168.1.231

slave1机:192.168.1.232(备用master)

六、大体步骤:



(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漂移。


3、mysql安装


一、下载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

二、解压后文件有:



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(能够解决一些兼容性)


三、安装


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

四、可能会报的错:


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


五、因为是RPM安装的因此在/etc/下没有MYSQL的my.cnf文件。解决方法:


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

这样能够修改MYSQL的一些配置文件了。


六、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

七、建立用户,用于主从复制的帐号


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

    username - 你将建立的用户名,

    host - 指定该用户在哪一个主机上能够登录,若是是本地用户可用localhost, 若是想让该用户能够从任意远程主机登录,可使用通配符%.

    password - 该用户的登录密码,密码能够为空,若是为空则该用户能够不须要密码登录服务器.

例如:

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

八、用户受权


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

例如:

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

FLUSH PRIVILEGES  //修改生效 

九、已能够远程访问数据库了。


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


4、建产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里设置的同样就行。


5、总结


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

相关文章
相关标签/搜索