mysql + mha + keepalive + vip_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.201master機:192.168.1.231slave1機: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=1log-bin=mysql-bin

binlog_format=mixed2.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不可以相同!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值