溫馨提示×

溫馨提示×

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

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

如何基于Kubernetes部署MySQL數(shù)據(jù)庫

發(fā)布時間:2021-11-03 16:36:03 來源:億速云 閱讀:205 作者:iii 欄目:MySQL數(shù)據(jù)庫

本篇內(nèi)容介紹了“如何基于Kubernetes部署MySQL數(shù)據(jù)庫”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

Kubernetes是Google開源的一個容器編排引擎,它支持自動化部署、大規(guī)模可伸縮、應用容器化管理。在生產(chǎn)環(huán)境中部署一個應用程序時,通常要部署該應用的多個實例以便對應用請求進行負載均衡

在Kubernetes中,我們可以創(chuàng)建多個容器,每個容器里面運行一個應用實例,然后通過內(nèi)置的負載均衡策略,實現(xiàn)對這一組應用實例的管理、發(fā)現(xiàn)、訪問,而這些細節(jié)都不需要運維人員去進行復雜的手工配置和處理。

創(chuàng)建服務 Service

創(chuàng)建一個 Service 為即將部署的 MySQL 數(shù)據(jù)庫固定連接的 IP,同時提供負載均衡,下面是 mysql-service.yaml 文件的內(nèi)容:

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

上述配置創(chuàng)建一個名稱為 mysql 的 Service 對象,它會將請求代理到使用 TCP 端口 3306,并且具有標簽 app=mysql 的 Pod 上。

創(chuàng)建資源:

kubectl create -f mysql-service.yaml

創(chuàng)建持久卷 PV

創(chuàng)建一個 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 # 卷可以被一個節(jié)點以讀寫方式掛載
  hostPath:
    path: "/mnt/data"

創(chuàng)建資源:

kubectl create -f mysql-pv.yaml

創(chuàng)建持久卷聲明 PVC

持久卷是集群中的資源,而持久卷聲明是對這些資源的請求,也被用來執(zhí)行對資源的聲明檢查。下面我們將創(chuàng)建名稱為 mysql-pvc 的持久卷聲明 mysql-pvc.yaml:

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

創(chuàng)建資源:

kubectl create -f mysql-pvc.yaml

部署 MySQL

在 3306 端口上使用 MySQL 5.7 的鏡像創(chuàng)建 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 # 生產(chǎn)環(huán)境中請使用 secret
              value: password
          ports:
            - containerPort: 3306
              name: mysql
          volumeMounts:
            - name: mysql-data
              mountPath: /var/lib/mysql
      volumes:
        - name: mysql-data
          persistentVolumeClaim:
            claimName: mysql-pvc

創(chuàng)建資源:

kubectl create -f mysql-deployment.yaml

連接 MySQL

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

“如何基于Kubernetes部署MySQL數(shù)據(jù)庫”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細節(jié)

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

AI