K8S搭建MySQL一主一從集群詳細(xì)步驟
引言
使用K8S搭建MySQL一主一從集群。
注意:以下全部內(nèi)容,需要把namespace: test中的test換成你要所部署集群所在的名稱空間。
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 的序號,生成 server-id [[ $(hostname) =~ -([0-9]+)$ ]] || exit 1 ordinal=${BASH_REMATCH[1]} echo [mysqld] > /mnt/conf.d/server-id.cnf # 由于 server-id 不能為 0,因此給 ID 加 100 來避開它 echo server-id=$((100 + $ordinal)) >> /mnt/conf.d/server-id.cnf # 如果 Pod 的序號為 0,說明它是 Master 節(jié)點,從 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 # 拷貝操作只需要在第一次啟動時進(jìn)行,所以數(shù)據(jù)已經(jīng)存在則跳過 [[ -d /var/lib/mysql/mysql ]] && exit 0 # Master 節(jié)點(序號為 0)不需要這個操作 [[ $(hostname) =~ -([0-9]+)$ ]] || exit 1 ordinal=${BASH_REMATCH[1]} [[ $ordinal == 0 ]] && exit 0 # 使用 ncat 指令,遠(yuǎn)程地從前一個節(jié)點拷貝數(shù)據(jù)到本地 ncat --recv-only mysql-$(($ordinal-1)).mysql 3307 | xbstream -x -C /var/lib/mysql # 執(zhí)行 --prepare,這樣拷貝來的數(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 個字段的值,用來拼裝集群初始化 SQL if [[ -f xtrabackup_slave_info ]]; then # 如果 xtrabackup_slave_info 文件存在,說明這個備份數(shù)據(jù)來自于另一個 Slave 節(jié)點 # 這種情況下,XtraBackup 工具在備份的時候,就已經(jīng)在這個文件里自動生成了 "CHANGE MASTER TO" SQL 語句 # 所以,只需要把這個文件重命名為 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 文件,說明備份來自于 Master 節(jié)點,就需要解析這個備份信息文件,讀取所需的兩個字段的值 [[ $(cat xtrabackup_binlog_info) =~ ^(.*?)[[:space:]]+(.*?)$ ]] || exit 1 rm xtrabackup_binlog_info # 把兩個字段的值拼裝成 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 容器啟動之后才能進(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 改個名字 # 防止這個 Container 重啟的時候,因為又找到了 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,組成一個完整的初始化和啟動 Slave 的 SQL 語句 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 端口。 # 它的作用是,在收到傳輸請求的時候,直接執(zhí)行 xtrabackup --backup 命令,備份 MySQL 的數(shù)據(jù)并發(fā)送給請求者 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)建完畢了。
總結(jié)
到此這篇關(guān)于K8S搭建MySQL一主一從集群的文章就介紹到這了,更多相關(guān)K8S搭建MySQL集群內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MYSQL與SQLserver之間存儲過程的轉(zhuǎn)換方式
這篇文章主要介紹了MYSQL與SQLserver之間存儲過程的轉(zhuǎn)換方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11mysql 5.7.21解壓版本安裝 Navicat數(shù)據(jù)庫操作工具安裝
這篇文章主要為大家詳細(xì)介紹了mysql 5.7.21解壓版本安裝,Navicat數(shù)據(jù)庫操作工具安裝,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-02-02Mysql 報Row size too large 65535 的原因及解決方法
這篇文章主要介紹了Mysql 報Row size too large 65535 的原因及解決方法 的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-06-06利用pt-heartbeat監(jiān)控MySQL的復(fù)制延遲詳解
這篇文章主要給大家介紹了利用pt-heartbeat監(jiān)控MySQL的復(fù)制延遲的相關(guān)資料,文中詳細(xì)介紹了pt-heartbeat、監(jiān)控原理以及安裝過程等的相關(guān)內(nèi)容,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-06-06linux環(huán)境下配置mysql5.6支持IPV6連接的方法
本文主要介紹在linux系統(tǒng)下,如何配置mysql支持IPV6的連接,本文圖文并茂給大家介紹的非常詳細(xì),具有參考借鑒價值,需要的朋友參考下吧2018-01-01對MySql經(jīng)常使用語句的全面總結(jié)(必看篇)
下面小編就為大家?guī)硪黄獙ySql經(jīng)常使用語句的全面總結(jié)(必看篇)。小編覺的挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03