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視頻教程》