溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

部署MySQL Galera Cluster的具體操作方法

發(fā)布時(shí)間:2020-06-05 17:15:08 來源:網(wǎng)絡(luò) 閱讀:424 作者:三月 欄目:MySQL數(shù)據(jù)庫

下文給大家?guī)黻P(guān)于部署MySQL Galera Cluster的具體操作方法,感興趣的話就一起來看看這篇文章吧,相信看完部署MySQL Galera Cluster的具體操作方法對大家多少有點(diǎn)幫助吧。

0.功能簡介

特性

  1. 基于行復(fù)制的完全并行同步復(fù)制
  2. 實(shí)時(shí)多主架構(gòu),任意節(jié)點(diǎn)可讀寫
  3. 無延遲復(fù)制,事務(wù)零丟失,可靠健壯的讀寫體驗(yàn)。
  4. 自動(dòng)化節(jié)點(diǎn)關(guān)系控制:節(jié)點(diǎn)故障自動(dòng)摘除,節(jié)點(diǎn)加入自動(dòng)協(xié)調(diào)
  5. 接近原生的MySQL數(shù)據(jù)庫連接的體驗(yàn)

原理簡析
當(dāng)一個(gè)事務(wù)在當(dāng)前寫入的節(jié)點(diǎn)提交后,通過wsrep API(write set replication API)將這個(gè)事務(wù)變成寫集(write set)廣播到同集群的其他節(jié)點(diǎn)中,其他節(jié)點(diǎn)收到寫集事務(wù)后,對這個(gè)事務(wù)進(jìn)行可行性檢查,并返回結(jié)果給wsrep API。
若大多數(shù)節(jié)點(diǎn)都預(yù)估自己可以成功執(zhí)行這個(gè)事務(wù),則wsrep API會(huì)做出仲裁,通知所有可以成功執(zhí)行這個(gè)事務(wù)的節(jié)點(diǎn)提交這個(gè)事務(wù),并將事務(wù)成功提交的消息返回給客戶端,同時(shí)根據(jù)需要剔除沒有成功執(zhí)行事務(wù)的節(jié)點(diǎn)

galera共享庫
galera本身是作為一個(gè)插件式的共享庫文件,MySQL通過調(diào)用galera寫集復(fù)制API掛鉤,獲得galera集群特性。

galera共享庫組成部分
galera庫是一個(gè)提供準(zhǔn)備,復(fù)制,應(yīng)用寫集事務(wù)功能的協(xié)議棧,其重要組成部分為:

wsrep API:寫集復(fù)制功能組件,負(fù)責(zé)提供關(guān)系型數(shù)據(jù)庫管理與復(fù)制服務(wù),定義接口
wsrep hooks:在數(shù)據(jù)庫引擎中的集成寫集組件
Gelera Provider:將共享庫轉(zhuǎn)化為wsrep API
Certification Layer:保護(hù)寫集并完整性,驗(yàn)證寫集完整性
replication:管理復(fù)制協(xié)議,提供完整的指令系統(tǒng)
GCS framwork:為集群組通信提供插件架構(gòu)

1.環(huán)境準(zhǔn)備

MySQL版本:5.6.41
192.168.33.14 node4
192.168.33.15 node5
192.168.33.16 node6

修改hosts文件

vim /etc/hosts
192.168.33.14 node4
192.168.33.15 node5
192.168.33.16 node6

2.安裝帶wsrep的mysql版本

# 分別在3臺(tái)服務(wù)器上安裝mysql
# 安裝基本工具
yum -y install lsof rsync wget

# 解壓
wget http://releases.galeracluster.com/mysql-wsrep-5.6/binary/mysql-wsrep-5.6.41-25.23-linux-x86_64.tar.gz
tar xf mysql-wsrep-5.6.41-25.23-linux-x86_64.tar.gz
mv mysql-wsrep-5.6.41-25.23-linux-x86_64 /usr/local/mysql

# 創(chuàng)建用戶及用戶組
groupadd -g 306 mysql
useradd -u 306 -g 306 mysql
chown -R mysql:mysql /usr/local/mysql

# 安裝依賴
yum -y install perl-Module-Install
cd /usr/local/mysql
./scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/home/mysql/mysqldata

# 配置開機(jī)啟動(dòng)
cp support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
if grep '^basedir=$' /etc/init.d/mysqld > /dev/null; then
    sed -i 's#^basedir=$#basedir=/usr/local/mysql#' /etc/init.d/mysqld
fi
if grep '^datadir=$' /etc/init.d/mysqld > /dev/null; then
    sed -i 's#^datadir=$#datadir=/home/mysql/mysqldata#' /etc/init.d/mysqld
fi
chkconfig --add mysqld
chkconfig mysqld on
service mysqld start

# 添加環(huán)境變量
cat > /etc/profile.d/mysql.sh <<EOF
export PATH=/usr/local/mysql/bin:$PATH
EOF
source /etc/profile

# 初始化配置
mysql_secure_installation <<EOF

y
oeasy808
oeasy808
y
n
y
y
EOF

# 配置完成之后,停止mysql服務(wù)
service mysqld stop

3.安裝galera

# 分別在3臺(tái)服務(wù)器上安裝galera
wget http://releases.galeracluster.com/galera-3/centos/7/x86_64/galera-3-25.3.24-2.el7.x86_64.rpm
yum -y install galera-3-25.3.24-2.el7.x86_64.rpm

4.配置集群

ip_addr=$(ip addr show $(ip route |grep default |awk '{print $5}')| grep inet |grep -Po '(\d+\.){3}\d+' | awk '{print $1;exit}')
mysql_id=$(echo $ip_addr | awk -F. '{print $NF}')
cat > /etc/my.cnf <<EOF
[mysqld]
skip-name-resolve=1
binlog_format=ROW
default-storage-engine=innodb
innodb_autoinc_lock_mode=2
innodb_locks_unsafe_for_binlog=1
query_cache_size=0
query_cache_type=0
bind_address=${ip_addr}
server-id=${mysql_id}

wsrep_on=ON
wsrep_provider=/usr/lib64/galera-3/libgalera_smm.so
wsrep_cluster_name="galera_cluster"
wsrep_cluster_address="gcomm://192.168.33.14,192.168.33.15,192.168.33.16" #全部集群節(jié)點(diǎn)
wsrep_node_name=cluster1 #節(jié)點(diǎn)名稱-唯一
wsrep_slave_threads=1
wsrep_certify_nonPK=1
wsrep_max_ws_rows=131072
wsrep_max_ws_size=1073741824
wsrep_debug=0
wsrep_convert_LOCK_to_trx=0
wsrep_retry_autocommit=1
wsrep_auto_increment_control=1
wsrep_drupal_282555_workaround=0
wsrep_causal_reads=0
#wsrep_notify_cmd=
wsrep_sst_method=rsync
wsrep_sst_auth=root:oeasy808 #安裝mysql時(shí)配置的密碼
EOF

5.啟動(dòng)集群

第一次在第1臺(tái)服務(wù)器上啟動(dòng)

/etc/init.d/mysqld bootstrap

在其他服務(wù)器上啟動(dòng)

service mysqld start

6.驗(yàn)證集群

# 查看集群節(jié)點(diǎn)狀態(tài)
mysql -p
> show status like 'wsrep%';
wsrep_incoming_addresses     | 192.168.33.16:3306,192.168.33.15:3306,192.168.33.14:3306
# 看到這個(gè)說明3個(gè)節(jié)點(diǎn)已經(jīng)加到集群中了

看了以上關(guān)于部署MySQL Galera Cluster的具體操作方法詳細(xì)內(nèi)容,是否有所收獲。如果想要了解更多相關(guān),可以繼續(xù)關(guān)注我們的行業(yè)資訊板塊。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI