MySQL之-MySQL高可用實作的詳細介紹

黄舟
發布: 2017-03-14 16:43:10
原創
1677 人瀏覽過

一、基本環境介紹及基本環境配置

節點1: node1.hulala.com      192.168.1.35     centos6.5_64  : node2.hulala.com      192.168.1.36     centos6.5_64    新增8G新硬碟
vvip #  192.168.1.39168.1.39

vip # #設定hosts解析:

vim /etc/sysconfig/network
HOSTNAME=node1.hulala.com
登入後複製

同步系統時間:

<br/>

vim /etc/hosts
192.168.1.35    node1.hulala.com node1
192.168.1.36    node2.hulala.com node2
登入後複製

關閉防火牆與SELINUX

<br/>

ntpdate cn.pool.ntp.org
登入後複製

以上配置在兩個節點都需要配置,配置完成之後重啟兩個節點

<br/>二:配置ssh互信

service iptables stop
chkconfig iptables off
cat /etc/sysconfig/selinux
SELINUX=disabled
登入後複製

三:DRBD的

安裝與配置<br/>(node1和node2執行相同操作)

[root@node1~]#ssh-keygen -t rsa -b 1024
[root@node1~]#ssh-copy-id root@192.168.1.36
[root@node2~]#ssh-keygen -t rsa -b 1024
[root@node2~]#ssh-copy-id root@192.168.1.35
登入後複製

取得一個sha1值做為shared-secret
[root@node1~]#wget -c http://www.php.cn/
[root@node1~]#wget -c http://www.php.cn/
[root@node1~]#rpm -ivh *.rpm
登入後複製

建立並編輯資源

設定檔<br/>:/etc/drbd.d/dbcluster. res

[root@node1~]#sha1sum /etc/drbd.conf
8a6c5f3c21b84c66049456d34b4c4980468bcfb3  /etc/drbd.conf
登入後複製
以上配置所用參數說明:RESOURCE: 資源名稱<br/>PROTOCOL: 使用協定”C”表示”同步的”,即收到遠端的寫入確認之後,則認為寫入完成.

NET: 兩個節點的SHA1 key是一樣的

after-sb-0pri : “Split Brain”發生時且沒有資料變更,兩節點之間正常連接<br/>after -sb-1pri : 如果有資料變更,則放棄輔設備資料,並且從主設備同步<br/>rr-conflict: 假如前面的設定不能應用,並且drbd系統有角色衝突的話,系統自動斷開節點間連接<br/>META-DISK: Meta data保存在同一個磁碟(sdb1)<br/>ON : 組成叢集的節點<br/>將DRBD配置拷貝到node機器:<br/><br/>

[root@node1~]# vim /etc/drbd.d/dbcluster.res
resource dbcluster {
    protocol C;
    net {
        cram-hmac-alg sha1;
        shared-secret "8a6c5f3c21b84c66049456d34b4c4980468bcfb3";
        after-sb-0pri discard-zero-changes;
after-sb-1pri discard-secondary;
        after-sb-2pri disconnect;
        rr-conflict disconnect;
    }
    device    /dev/drbd0;
    disk      /dev/sdb1;
meta-disk internal;
    on node1.hulala.com {
        address   192.168.1.35:7789;
    }
    on node2.hulala.com {
        address   192.168.1.36:7789;
    }
}
登入後複製
<br/>建立資源及<br/>檔案系統<br/>:

建立分割區(未格式化過)

在node1和node2上建立LVM分割區:

[root@node1~]#scp /etc/drbd.d/dbcluster.res root@192.168.1.36:/etc/drbd.d/
登入後複製
<br/>在node1和node2上給資源(dbcluster)建立meta data:<br/><br/>
[#root@node1~]fdisk /dev/sdb
登入後複製

啟動資源(node1和node2都得查看)

– 首先確保drbd <br/>module

#已經載入

查看是否載入:<br/>

若未載入,則需載入:<br/><br/>
# lsmod | grep drbd
登入後複製

– 啟動drbd後台程序:

<br/>

# modprobe drbd
# lsmod | grep drbd
drbd                  317261  0
libcrc32c               1246  1 drbd
登入後複製

#查看(node1和node2)drbd狀態:

<br/>

[root@node1 drbd]# drbdadm up dbcluster
[root@node2 drbd]# drbdadm up dbcluster
登入後複製

從上面的資訊可以看到,DRBD服務已經在兩台機器上運行,但任何一台機器都不是主機器(“primary” host),因此無法存取到資源(block device).

開始同步:<br/>

僅在主節點操作(這裡為node1)

<br/>

[root@node2 drbd]# /etc/init.d/drbd status
GIT-hash: 7ad5f850d711223713d6dcadc3dd48860321070c build by dag@Build64R6, 2016-10-23 08:16:10
m:res        cs         ro                   ds                         p  mounted  fstype
0:dbcluster  Connected  Secondary/Secondary  Inconsistent/Inconsistent  C
登入後複製

查看同步狀態:

<br/>#

[root@node1 drbd]# drbdadm — –overwrite-data-of-peer primary dbcluster
登入後複製

上面的輸出結果的一些說明:

cs (connection state): 網路連線狀態<br/>ro (roles): 節點的角色(本節點的角色首先顯示)

ds ( disk states):硬碟的狀態

複製協定: A, B or C(本配置是C)<br/>看到drbd狀態為」cs:Connected ro:Primary/Secondary ds:UpToDate/UpToDate」即表示同步結束.<br/>也可以這樣查看drbd狀態:<br/><br/>

<br/>
登入後複製
<br/>建立檔案系統:<br/>在主節點(Node1)建立檔案系統:<br/>

[root@centos193 drbd]# drbd-overview
  0:dbcluster/0  Connected Secondary/Primary UpToDate/UpToDate C r—–
登入後複製

#註:沒必要在輔節點(Node2)做同樣的操作,因為DRBD會處理原始磁碟資料的同步.<br/>另外,我們也不需要將這個DRBD系統掛載到任何一台機器(當然安裝<br/> MySQL

的時候需要暫時掛載來安裝MySQL),因為叢集管理軟體會處理.還有要確保複製的檔案系統僅僅掛載在Active的主伺服器上.

<br/>四:mysql的安裝<br/>MySQL的安裝也可以參考博文《MySQL之-CentOS6.5 編譯安裝MySQL5.6.16》

1,在node1和node2節點安裝mysql:

<br/>

[root@node1 drbd]# mkfs -t ext4 /dev/drbd0
mke2fs 1.41.12 (17-May-2010)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
…….
180 days, whichever comes first.  Use tune2fs -c or -i to override.
登入後複製

2.node1和node2都操作停止mysql服務

<br/>

yum install mysql* -y
登入後複製

3.node1和node2都操作建立資料庫目錄並將該目錄權限屬主修改為mysql

<br/>

[root@node1~]# service mysql stop
Shutting down MySQL.        [  OK  ]
登入後複製

4,關閉mysql暫時掛載DRBD檔案系統到主節點(Node1)

<br/>

[root@host1 /]# mkdir -p /mysql/data
[root@host1 /]# chown -R mysql:mysql /mysql
登入後複製

5.node1和node2都操作修改my.cnf檔案修改

在[mysqld]下新增新的資料存放路徑<br/>

[root@node1 ~]# mount /dev/drbd0  /mysql/
登入後複製

6.將預設的資料路徑下的所有檔案和目錄cp到新的目錄下(node2不用操作)<br/> <br/>

datadir=/mysql/data
登入後複製

node1和node2都操作這裡注意copy過去的目錄權限屬主需要修改為mysql,這裡直接修改mysql目錄即可.

<br/>

[root@host1 mysql]#cd /var/lib/mysql
[root@host1 mysql]#cp -R * /mysql/data/
登入後複製

7.啟動node1上的mysql進行登陸測試

<br/>

[root@host1 mysql]# chown -R mysql:mysql /mysql
登入後複製

8.在節點Node1卸載DRBD檔案系統

<br/>

[root@host1 mysql]# mysql
登入後複製

9.將DRBD檔案系統掛載節點Node2

<br/>#

[root@node1 ~]# umount /var/lib/mysql_drbd
[root@node1 ~]# drbdadm secondary dbcluster
登入後複製

10.節點Node2上配置MySQL並測試

<br/>

[root@node2 ~]# drbdadm primary dbcluster
[root@node2 ~]# mount /dev/drbd0 /mysql/
登入後複製

11. node2上做mysql登陸測試

<br/>

[root@node1 ~]# scp node2:/etc/my.cnf /etc/my.cnf
[root@node2 ~]# chown mysql /etc/my.cnf
[root@node2 ~]# chmod 644 /etc/my.cnf
登入後複製

12.在Node2上卸載DRBD檔案系統,交由叢集管理軟體Pacemaker來管理

<br/>

[root@node2 ~]# mysql
登入後複製

五:Corosync和Pacemaker的安裝設定(node1和node2都需安裝)

<br/>安裝Pacemaker必須依賴:

#
[root@node2~]# umount /var/lib/mysql_drbd
[root@node2~]# drbdadm secondary dbcluster
[root@node2~]# drbd-overview
  0:dbcluster/0  Connected Secondary/Secondary UpToDate/UpToDate C r—–
[root@node2~]#
登入後複製

安裝Cluster Stack依賴:

<br/>

[root@node1~]#yum -y install automake autoconf libtool-ltdl-devel pkgconfig python glib2-devel libxml2-devel 
libxslt-devel python-devel gcc-c++ bzip2-devel gnutls-devel pam-devel libqb-devel
登入後複製

安裝Pacemaker可選依賴:

<br/>

[root@node1~]yum -y install clusterlib-devel corosynclib-devel
登入後複製

Pacemaker安裝:

<br/>

[root@node1~]yum -y install pacemaker
登入後複製

crmsh安装:<br/>

[root@node1~]wget http://www.php.cn/:/ha-clustering:/Stable/CentOS_CentOS-6/network:ha-clustering:Stable.repo
[root@node1~]yum -y install crmsh
登入後複製

1,配置corosync<br/>Corosync Key<br/>– 生成节点间安全通信的key:<br/>

[root@node1~]# corosync-keygen
登入後複製
– 将authkey拷贝到node2节点(保持authkey的权限为400):
[root@node~]# scp /etc/corosync/authkey node2:/etc/corosync/
2,[root@node1~]# cp /etc/corosync/corosync.conf.example /etc/corosync/corosync.conf
登入後複製

编辑/etc/corosync/corosync.conf:<br/>

# Please read the corosync.conf.5 manual page
compatibility: whitetank
aisexec {
        user: root
        group: root
}
totem {
        version: 2
secauth: off
threads: 0
interface {
ringnumber: 0
bindnetaddr: 192.168.1.0
mcastaddr: 226.94.1.1
mcastport: 4000
ttl: 1
}
}
logging {
fileline: off
to_stderr: no
to_logfile: yes
to_syslog: yes
logfile: /var/log/cluster/corosync.log
debug: off
timestamp: on
logger_subsys {
subsys: AMF
debug: off
}
}
amf {
mode: disabled
}
登入後複製

– 创建并编辑/etc/corosync/service.d/pcmk,添加”pacemaker”服务<br/>

[root@node1~]# cat /etc/corosync/service.d/pcmk
service {
	# Load the Pacemaker Cluster Resource Manager
	name: pacemaker
	ver: 1
}
登入後複製

将上面两个配置文件拷贝到另一节点<br/>

[root@node1]# scp /etc/corosync/corosync.conf node2:/etc/corosync/corosync.conf
[root@node1]# scp /etc/corosync/service.d/pcmk node2:/etc/corosync/service.d/pcmk
登入後複製

3,启动corosync和Pacemaker<br/> 分别在两个节点上启动corosync并检查.<br/>

[root@node1]# /etc/init.d/corosync start
Starting Corosync Cluster Engine (corosync):               [  OK  ]
[root@node1~]# corosync-cfgtool -s
Printing ring status.
Local node ID -1123964736
RING ID 0
id = 192.168.1.189
status = ring 0 active with no faults
[root@node2]# /etc/init.d/corosync start
Starting Corosync Cluster Engine (corosync):               [  OK  ]
登入後複製

– 在两节点上分别启动Pacemaker:<br/>

[root@node1~]# /etc/init.d/pacemaker start
Starting Pacemaker Cluster Manager:                        [  OK  ]
[root@node2~]# /etc/init.d/pacemaker start
Starting Pacemaker Cluster Manager:
登入後複製

六、资源配置

<br/>配置资源及约束 <br/>配置默认属性<br/>查看已存在的配置:

[root@node1 ~]# crm configure property stonith-enabled=false
[root@node1 ~]# crm_verify -L
登入後複製
登入後複製

禁止STONITH错误:<br/>

[root@node1 ~]# crm configure property stonith-enabled=false
[root@node1 ~]# crm_verify -L
登入後複製
登入後複製

让集群忽略Quorum:<br/>

[root@node1~]# crm configure property no-quorum-policy=ignore
登入後複製

防止资源在恢复之后移动:<br/>

[root@node1~]# crm configure rsc_defaults resource-stickiness=100
登入後複製

设置操作的默认超时:<br/>

[root@node1~]# crm configure property default-action-timeout="180s"
登入後複製

设置默认的启动失败是否为致命的:

[root@node1~]# crm configure property start-failure-is-fatal="false"
登入後複製

配置DRBD资源<br/>– 配置之前先停止DRBD:<br/>

[root@node1~]# /etc/init.d/drbd stop
[root@node2~]# /etc/init.d/drbd stop
登入後複製

– 配置DRBD资源:<br/>

[root@node1~]# crm configure
crm(live)configure# primitive p_drbd_mysql ocf:linbit:drbd params drbd_resource="dbcluster" op monitor interval="15s"
 op start timeout="240s" op stop timeout="100s"
登入後複製

– 配置DRBD资源主从关系(定义只有一个Master节点):<br/>

crm(live)configure# ms ms_drbd_mysql p_drbd_mysql meta master-max="1" master-node-max="1" 
clone-max="2" clone-node-max="1" notify="true"
登入後複製

– 配置文件系统资源,定义挂载点(mount point):<br/>

crm(live)configure# primitive p_fs_mysql ocf:heartbeat:Filesystem params device="/dev/drbd0" directory="/var/lib/mysql_drbd/" fstype="ext4"
登入後複製

配置VIP资源<br/>

crm(live)configure# primitive p_ip_mysql ocf:heartbeat:IPaddr2 params ip="192.168.1.39" cidr_netmask="24" op 
monitor interval="30s"
登入後複製

配置MySQL资源<br/>

crm(live)configure# primitive p_mysql lsb:mysql op monitor interval="20s" 
timeout="30s" op start interval="0" timeout="180s" op stop interval="0" timeout="240s"
登入後複製

七、组资源和约束

通过”组”确保DRBD,MySQL和VIP是在同一个节点(Master)并且确定资源的启动/停止顺序.<br/>

启动: p_fs_mysql–>p_ip_mysql->p_mysql
停止: p_mysql–>p_ip_mysql–>p_fs_mysql
登入後複製
crm(live)configure# group g_mysql p_fs_mysql p_ip_mysql p_mysql
登入後複製

组group_mysql永远只在Master节点:<br/>

crm(live)configure# colocation c_mysql_on_drbd inf: g_mysql ms_drbd_mysql:Master
登入後複製

MySQL的启动永远是在DRBD Master之后:<br/>

crm(live)configure# order o_drbd_before_mysql inf: ms_drbd_mysql:promote g_mysql:start
登入後複製

配置检查和提交<br/>

crm(live)configure# verify
crm(live)configure# commit
crm(live)configure# quit
登入後複製

查看集群状态和failover测试<br/>状态查看:<br/>

[root@node1 mysql]# crm_mon -1r
登入後複製

Failover测试:<br/>将Node1设置为Standby状态<br/>

[root@node1 ~]# crm node standby
登入後複製

过几分钟查看集群状态(若切换成功,则看到如下状态):<br/>

[root@node1 ~]# crm status
登入後複製

将Node1恢复online状态:<br/>

[root@node1 mysql]# crm node online
[root@node1 mysql]# crm status
登入後複製

以上是MySQL之-MySQL高可用實作的詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板