基于 Kubernetes 部署 MySQL 数据库

Posted Javachichi

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于 Kubernetes 部署 MySQL 数据库相关的知识,希望对你有一定的参考价值。

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

创建服务 Service

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

apiVersion: v1
kind: Service
metadata:
  name: mysql
spec:
  selector:
    app: mysql
  ports:
    - port: 3306 

上述配置创建一个名称为 mysqlService 对象,它会将请求代理到使用 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 

如果你觉得自己学习效率低,缺乏正确的指导,可以加入资源丰富,学习氛围浓厚的技术圈一起学习交流吧!
[Java架构群]
群内有许多来自一线的技术大牛,也有在小厂或外包公司奋斗的码农,我们致力打造一个平等,高质量的JAVA交流圈子,不一定能短期就让每个人的技术突飞猛进,但从长远来说,眼光,格局,长远发展的方向才是最重要的。

部署 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 

最后

以下是Java面试1—到5年以上开发必问到的面试问点,也都是一线互联网公司Java面试必备技能,下面是参照阿里年薪50W所需具备的技能图,大家可以参考下!
在这里插入图片描述

同时针对这12个技能,我在这整理了一份Java架构进阶面试专题PDF文档(含450题解析,包括Dubbo、Redis、Netty、zookeeper、Spring cloud、分布式、高并发,设计模式,MySQL等知识点解析,内容丰富,图文结合!)

蚂蚁金服Java研发岗三面:MySQL+秒杀+Redis+JVM等(终获offer)
这份专题文档是免费分享的,有需要的朋友可以看向下面来获取!!

需要完整版文档的小伙伴,可以一键三连,下方获取免费领取方式!
在这里插入图片描述

以上是关于基于 Kubernetes 部署 MySQL 数据库的主要内容,如果未能解决你的问题,请参考以下文章

基于Kubernetes(k8s)部署Dubbo+Nacos服务

在kubernetes集群中部署php应用

云原生Kubernetes(k8s)部署 MySQL+Dubbo+Nacos服务

kubernetes系列:kubernetes部署mysql(单节点)

Docker&Kubernetes ❀ Docker部署MySQL案例

在kubernetes中创建tomcat与mysql集群