首頁 >資料庫 >mysql教程 >Kubernetes是什麼?如何基於它部署MySQL資料庫

Kubernetes是什麼?如何基於它部署MySQL資料庫

藏色散人
藏色散人轉載
2021-11-03 16:30:551950瀏覽

Kubernetes是Google開源的容器編排引擎,它支援自動化部署、大規模可擴展、應用容器化管理。在生產環境中部署一個應用程式時,通常會部署該應用程式的多個執行個體以便對應用程式請求進行負載平衡。

在Kubernetes中,我們可以建立多個容器,每個容器裡面運行一個應用實例,然後透過內建的負載平衡策略,實現對這一組應用實例的管理、發現、訪問,而這些細節都不需要維運人員去進行複雜的手動配置和處理。

本文將介紹如何基於 Kubernetes 部署 MySQL 資料庫。

建立服務Service

建立一個Service 為即將部署的MySQL 資料庫固定連線的IP,同時提供負載平衡,以下是mysql-service.yaml 檔案的內容:

apiVersion: v1
kind: Service
metadata:
  name: mysql
spec:
  selector:
    app: mysql
  ports:
    - port: 3306

上述配置建立一個名稱為mysql 的Service 對象,它會將請求代理到使用TCP 連接埠3306,並且具有標籤app=mysql 的Pod 上。

建立資源:

kubectl create -f mysql-service.yaml

建立持久性卷PV

#建立一個MySQL 的持久性卷宗mysql-pv.yaml(當Pod 不再存在時,Kubernetes 也會銷毀臨時磁碟區;不過Kubernetes 不會銷毀持久性磁碟區。):

apiVersion: v1
kind: PersistentVolume
metadata:
  name: mysql-pv
  labels:
    type: local
spec:
  storageClassName: manual
  capacity:
    storage: 20Gi
  accessModes:
    - ReadWriteOnce # 卷可以被一个节点以读写方式挂载
  hostPath:
    path: "/mnt/data"

建立資源:

kubectl create -f mysql-pv.yaml

建立持久性磁碟區宣告PVC

持久性磁碟區是叢集中的資源,而持久性磁碟區宣告是對這些資源的請求,也被用來執行對資源的宣告檢查。下面我們將建立名稱為mysql-pvc 的持久性卷聲明mysql-pvc.yaml:

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysql-pvc
spec:
  storageClassName: manual
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 20Gi

建立資源:

kubectl create -f mysql-pvc.yaml

#部署MySQL

#在3306 連接埠上使用MySQL 5.7 的映像建立Pod,mysql-deployment.yaml:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: mysql
spec:
  selector:
    matchLabels:
      app: mysql
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
        - image: mysql:5.7
          name: mysql
          env:
            - name: MYSQL_ROOT_PASSWORD # 生产环境中请使用 secret
              value: password
          ports:
            - containerPort: 3306
              name: mysql
          volumeMounts:
            - name: mysql-data
              mountPath: /var/lib/mysql
      volumes:
        - name: mysql-data
          persistentVolumeClaim:
            claimName: mysql-pvc

建立資源:

kubectl create -f mysql-deployment.yaml

連接MySQL

kubectl run -it --rm --image=mysql:5.6 --restart=Never mysql-client -- mysql -hmysql -ppassword

推薦學習:《mysql影片教學

以上是Kubernetes是什麼?如何基於它部署MySQL資料庫的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:juejin.im。如有侵權,請聯絡admin@php.cn刪除