Kubernetes是什么?如何基于它部署MySQL数据库

Kubernetes是什么?如何基于它部署MySQL数据库,第1张

概述Kubernetes是什么?如何基于它部署MySQL数据库

Kubernetes是Google开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。在生产环境中部署一个应用程序时,通常要部署该应用的多个实例以便对应用请求进行负载均衡。

在Kubernetes中,我们可以创建多个容器,每个容器里面运行一个应用实例,然后通过内置的负载均衡策略,实现对这一组应用实例的管理、发现、访问,而这些细节都不需要运维人员去进行复杂的手工配置和处理。

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

创建服务 Service

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

APIVersion: v1kind: ServiceMetadata:  name: MysqLspec:  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: v1kind: PersistentVolumeMetadata:  name: MysqL-pv  labels:    type: localspec:  storageClassname: manual  capacity:    storage: 20Gi  accessModes:    - ReaDWriteOnce # 卷可以被一个节点以读写方式挂载  hostPath:    path: "/mnt/data"

创建资源:

kubectl create -f MysqL-pv.yaml

创建持久卷声明 PVC

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

APIVersion: v1kind: PersistentVolumeClaimMetadata:  name: MysqL-pvcspec:  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/v1kind: DeploymentMetadata:  name: MysqLspec:  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数据库全部内容,希望文章能够帮你解决Kubernetes是什么?如何基于它部署MySQL数据库所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1149945.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存