一、總概:
本文介紹了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 '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不可以相同!