基于 Kubernetes 部署 MySQL 数据库

本文将介绍如何基于 Kubernetes 部署 MySQL 数据库。

创建服务 Service

创建一个 Service 为即将部署的 MySQL 数据库固定连接的 IP,同时提供负载均衡,下面是 mysql-service.yaml 文件的内容:

 
yaml
复制代码
apiVersion: v1
kind: Service
metadata:
  name: mysql
spec:
  selector:
    app: mysql
  ports:
    - port: 3306

上述配置创建一个名称为 mysqlService 对象,它会将请求代理到使用 TCP 端口 3306,并且具有标签 app=mysql 的 Pod 上。

创建资源:

 
bash
复制代码
kubectl create -f mysql-service.yaml

创建持久卷 PV

创建一个 MySQL 的持久卷 mysql-pv.yaml(当 Pod 不再存在时,Kubernetes 也会销毁临时卷;不过 Kubernetes 不会销毁 持久卷。):

 
yaml
复制代码
apiVersion: v1
kind: PersistentVolume
metadata:
  name: mysql-pv
  labels:
    type: local
spec:
  storageClassName: manual
  capacity:
    storage: 20Gi
  accessModes:
    - ReadWriteOnce # 卷可以被一个节点以读写方式挂载
  hostPath:
    path: "/mnt/data"

创建资源:

 
bash
复制代码
kubectl create -f mysql-pv.yaml

创建持久卷声明 PVC

持久卷是集群中的资源,而持久卷声明是对这些资源的请求,也被用来执行对资源的声明检查。下面我们将创建名称为 mysql-pvc 的持久卷声明 mysql-pvc.yaml

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

创建资源:

 
bash
复制代码
kubectl create -f mysql-pvc.yaml

部署 MySQL

在 3306 端口上使用 MySQL 5.7 的镜像创建 Pod,mysql-deployment.yaml

 
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

创建资源:

 
bash
复制代码
kubectl create -f mysql-deployment.yaml

连接 MySQL

 
bash
复制代码
kubectl run -it --rm --image=mysql:5.6 --restart=Never mysql-client -- mysql -hmysql -ppassword

作者:K8sCat
链接:https://juejin.cn/post/6972937193551724552
来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
posted @   GaoYanbing  阅读(94)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示