Kubernetes は、Google がオープンソース化したコンテナ オーケストレーション エンジンで、自動デプロイメント、大規模なスケーラビリティ、アプリケーション コンテナ管理をサポートしています。実稼働環境にアプリケーションをデプロイするときは、通常、アプリケーションの複数のインスタンスをデプロイして、アプリケーション リクエストの負荷を分散します。
Kubernetes では、複数のコンテナを作成し、各コンテナでアプリケーション インスタンスを実行し、組み込みの負荷分散戦略を使用して、このアプリケーション インスタンスのグループの管理、検出、アクセスを実現できます。詳細については、運用担当者や保守担当者が複雑な手動構成や処理を実行する必要はありません。
この記事では、Kubernetes に基づいて MySQL データベースをデプロイする方法を紹介します。
サービスの作成 Service
デプロイする MySQL データベースの IP アドレスを固定し、負荷分散を提供するサービスを作成します。 service.yaml ファイル。:
apiVersion: v1 kind: Service metadata: name: mysql spec: selector: app: mysql ports: - port: 3306
上記の設定では、mysql という名前の Service オブジェクトが作成され、TCP ポート 3306 を使用し、ラベル app=mysql を持つリクエストをポッドにプロキシします。
リソースの作成:
kubectl create -f mysql-service.yaml
永続ボリュームの作成 PV
MySQL 永続ボリューム mysql-pv.yaml の作成 (ポッドが存在しなくなった場合) 、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
Deploy MySQL
Createポート 3306 の MySQL 5.7 イメージを使用するポッド、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 中国語 Web サイトの他の関連記事を参照してください。