您好,登錄后才能下訂單哦!
本篇內容介紹了“如何基于Kubernetes部署MySQL數據庫”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
Kubernetes是Google開源的一個容器編排引擎,它支持自動化部署、大規模可伸縮、應用容器化管理。在生產環境中部署一個應用程序時,通常要部署該應用的多個實例以便對應用請求進行負載均衡。
在Kubernetes中,我們可以創建多個容器,每個容器里面運行一個應用實例,然后通過內置的負載均衡策略,實現對這一組應用實例的管理、發現、訪問,而這些細節都不需要運維人員去進行復雜的手工配置和處理。
創建服務 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
“如何基于Kubernetes部署MySQL數據庫”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。