ホームページ > データベース > mysql チュートリアル > Kubernetesとは何ですか? MySQL データベースをベースにしてデプロイする方法

Kubernetesとは何ですか? MySQL データベースをベースにしてデプロイする方法

藏色散人
リリース: 2021-11-03 16:30:55
転載
1988 人が閲覧しました

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 サイトの他の関連記事を参照してください。

関連ラベル:
ソース:juejin.im
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート