使用K8S搭建MySQL一主一從集群。
注意:以下全部?jī)?nèi)容,需要把namespace: test中的test換成你要所部署集群所在的名稱空間。文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-701859.html
1、創(chuàng)建密鑰
apiVersion: v1
kind: Secret
metadata:
name: mysql-secret
namespace: etc2
labels:
app: mysql
type: Opaque
data:
password: MTIzNDU2Cg== # base64加密后密碼
2、創(chuàng)建ConfigMap
apiVersion: v1
kind: ConfigMap
metadata:
name: mysql
namespace: test
labels:
app: mysql
data:
master.cnf: |
# Master
[mysqld]
log-bin=mysqllog
skip-name-resolve
slave.cnf: |
# Slave
[mysqld]
super-read-only
skip-name-resolve
log-bin=mysql-bin
replicate-ignore-db=mysql
3、創(chuàng)建StatefulSet
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: mysql
namespace: test
labels:
app: mysql
spec:
selector:
matchLabels:
app: mysql
serviceName: mysql
replicas: 2 # 副本數(shù)量,集群中的數(shù)量
template:
metadata:
labels:
app: mysql
spec:
initContainers:
- name: init-mysql
image: mysql:5.7.33
env:
- name: MYSQL_ROOT_PASSWORD
valueFrom:
secretKeyRef:
name: mysql-secret
key: password
command:
- bash
- "-c"
- |
set -ex
# 從 Pod 的序號(hào),生成 server-id
[[ $(hostname) =~ -([0-9]+)$ ]] || exit 1
ordinal=${BASH_REMATCH[1]}
echo [mysqld] > /mnt/conf.d/server-id.cnf
# 由于 server-id 不能為 0,因此給 ID 加 100 來(lái)避開它
echo server-id=$((100 + $ordinal)) >> /mnt/conf.d/server-id.cnf
# 如果 Pod 的序號(hào)為 0,說(shuō)明它是 Master 節(jié)點(diǎn),從 ConfigMap 里把 Master 的配置文件拷貝到 /mnt/conf.d 目錄下
# 否則,拷貝 ConfigMap 里的 Slave 的配置文件
if [[ ${ordinal} -eq 0 ]]; then
cp /mnt/config-map/master.cnf /mnt/conf.d
else
cp /mnt/config-map/slave.cnf /mnt/conf.d
fi
volumeMounts:
- name: conf
mountPath: /mnt/conf.d
- name: config-map
mountPath: /mnt/config-map
- name: clone-mysql
#image: gcr.io/google-samples/xtrabackup:1.0
image: registry.cn-shenzhen.aliyuncs.com/jbjb/csi:xtrabackup-1.0
env:
- name: MYSQL_ROOT_PASSWORD
valueFrom:
secretKeyRef:
name: mysql-secret
key: password
command:
- bash
- "-c"
- |
set -ex
# 拷貝操作只需要在第一次啟動(dòng)時(shí)進(jìn)行,所以數(shù)據(jù)已經(jīng)存在則跳過(guò)
[[ -d /var/lib/mysql/mysql ]] && exit 0
# Master 節(jié)點(diǎn)(序號(hào)為 0)不需要這個(gè)操作
[[ $(hostname) =~ -([0-9]+)$ ]] || exit 1
ordinal=${BASH_REMATCH[1]}
[[ $ordinal == 0 ]] && exit 0
# 使用 ncat 指令,遠(yuǎn)程地從前一個(gè)節(jié)點(diǎn)拷貝數(shù)據(jù)到本地
ncat --recv-only mysql-$(($ordinal-1)).mysql 3307 | xbstream -x -C /var/lib/mysql
# 執(zhí)行 --prepare,這樣拷貝來(lái)的數(shù)據(jù)就可以用作恢復(fù)了
xtrabackup --prepare --target-dir=/var/lib/mysql
volumeMounts:
- name: data
mountPath: /var/lib/mysql
subPath: mysql
- name: conf
mountPath: /etc/mysql/conf.d
containers:
- name: mysql
image: mysql:5.7.33
env:
- name: MYSQL_ROOT_PASSWORD
valueFrom:
secretKeyRef:
name: mysql-secret
key: password
ports:
- name: mysql
containerPort: 3306
volumeMounts:
- name: data
mountPath: /var/lib/mysql
subPath: mysql
- name: conf
mountPath: /etc/mysql/conf.d
resources:
requests:
cpu: 500m
memory: 1Gi
livenessProbe:
exec:
command: ["mysqladmin", "ping", "-uroot", "-p${MYSQL_ROOT_PASSWORD}"]
initialDelaySeconds: 30
periodSeconds: 10
timeoutSeconds: 5
readinessProbe:
exec:
command: ["mysqladmin", "ping", "-uroot", "-p${MYSQL_ROOT_PASSWORD}"]
initialDelaySeconds: 5
periodSeconds: 2
timeoutSeconds: 1
- name: xtrabackup
image: registry.cn-shenzhen.aliyuncs.com/jbjb/csi:xtrabackup-1.0
ports:
- name: xtrabackup
containerPort: 3307
env:
- name: MYSQL_ROOT_PASSWORD
valueFrom:
secretKeyRef:
name: mysql-secret
key: password
command:
- bash
- "-c"
- |
set -ex
cd /var/lib/mysql
# 從備份信息文件里讀取 MASTER_LOG_FILE 和 MASTER_LOG_POS 這 2 個(gè)字段的值,用來(lái)拼裝集群初始化 SQL
if [[ -f xtrabackup_slave_info ]]; then
# 如果 xtrabackup_slave_info 文件存在,說(shuō)明這個(gè)備份數(shù)據(jù)來(lái)自于另一個(gè) Slave 節(jié)點(diǎn)
# 這種情況下,XtraBackup 工具在備份的時(shí)候,就已經(jīng)在這個(gè)文件里自動(dòng)生成了 "CHANGE MASTER TO" SQL 語(yǔ)句
# 所以,只需要把這個(gè)文件重命名為 change_master_to.sql.in,后面直接使用即可
mv xtrabackup_slave_info change_master_to.sql.in
# 所以,也就用不著 xtrabackup_binlog_info 了
rm -f xtrabackup_binlog_info
elif [[ -f xtrabackup_binlog_info ]]; then
# 如果只是存在 xtrabackup_binlog_info 文件,說(shuō)明備份來(lái)自于 Master 節(jié)點(diǎn),就需要解析這個(gè)備份信息文件,讀取所需的兩個(gè)字段的值
[[ $(cat xtrabackup_binlog_info) =~ ^(.*?)[[:space:]]+(.*?)$ ]] || exit 1
rm xtrabackup_binlog_info
# 把兩個(gè)字段的值拼裝成 SQL,寫入 change_master_to.sql.in 文件
echo "CHANGE MASTER TO MASTER_LOG_FILE='${BASH_REMATCH[1]}',\
MASTER_LOG_POS=${BASH_REMATCH[2]}" > change_master_to.sql.in
fi
# 如果存在 change_master_to.sql.in,就意味著需要做集群初始化工作
if [[ -f change_master_to.sql.in ]]; then
# 但一定要先等 MySQL 容器啟動(dòng)之后才能進(jìn)行下一步連接 MySQL 的操作
echo "Waiting for mysqld to be ready(accepting connections)"
until mysql -h 127.0.0.1 -uroot -p${MYSQL_ROOT_PASSWORD} -e "SELECT 1"; do sleep 1; done
echo "Initializing replication from clone position"
# 將文件 change_master_to.sql.in 改個(gè)名字
# 防止這個(gè) Container 重啟的時(shí)候,因?yàn)橛终业搅?change_master_to.sql.in,從而重復(fù)執(zhí)行一遍初始化流程
mv change_master_to.sql.in change_master_to.sql.orig
# 使用 change_master_to.sql.orig 的內(nèi)容,也就是前面拼裝的 SQL,組成一個(gè)完整的初始化和啟動(dòng) Slave 的 SQL 語(yǔ)句
mysql -h 127.0.0.1 -uroot -p${MYSQL_ROOT_PASSWORD} << EOF
$(< change_master_to.sql.orig),
MASTER_HOST='mysql-0.mysql.mysql',
MASTER_USER='root',
MASTER_PASSWORD='${MYSQL_ROOT_PASSWORD}',
MASTER_CONNECT_RETRY=10;
START SLAVE;
EOF
fi
# 使用 ncat 監(jiān)聽 3307 端口。
# 它的作用是,在收到傳輸請(qǐng)求的時(shí)候,直接執(zhí)行 xtrabackup --backup 命令,備份 MySQL 的數(shù)據(jù)并發(fā)送給請(qǐng)求者
exec ncat --listen --keep-open --send-only --max-conns=1 3307 -c \
"xtrabackup --backup --slave-info --stream=xbstream --host=127.0.0.1 --user=root --password=${MYSQL_ROOT_PASSWORD}"
volumeMounts:
- name: data
mountPath: /var/lib/mysql
subPath: mysql
- name: conf
mountPath: /etc/mysql/conf.d
volumes:
- name: conf
emptyDir: {}
- name: config-map
configMap:
name: mysql
volumeClaimTemplates:
- metadata:
name: data
#annotations:
#volume.beta.kubernetes.io/storage-class: nfs-csi
spec:
accessModes:
- "ReadWriteOnce"
storageClassName: nfs-storage #需要和你自己創(chuàng)建的class.yaml保持名稱一致
resources:
requests:
storage: 5Gi
---
apiVersion: v1
kind: Service
metadata:
name: mysql
namespace: test
labels:
app: mysql
spec:
type: NodePort
ports:
- name: mysql
port: 3306
selector:
app: mysql
---
apiVersion: v1
kind: Service
metadata:
name: mysql-read
namespace: test
labels:
app: mysql
spec:
#從MySQL如想暴漏端口
#type: NodePort
ports:
- name: mysql
port: 3306
selector:
app: mysql
以上,MySQL的一主一從集群就創(chuàng)建完畢了。文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-701859.html
到了這里,關(guān)于K8S搭建MySQL集群的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!