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不能夠相同

相關文章
相關標籤/搜索