K8s部署MySQL

在Kubernetes(简称K8s)上部署MySQL通常涉及以下几个步骤:创建MySQL的Docker镜像(或使用现有的镜像)、编写Kubernetes配置文件(YAML文件)、应用这些配置以创建Pod、Service、Persistent Volume(持久卷)和Persistent Volume Claim(持久卷声明)。

  1. 准备MySQL Docker镜像

虽然你可以自己构建MySQL Docker镜像,但通常直接使用官方的MySQL镜像会更加方便。

【bash】

docker pull mysql:latest

  1. 编写Kubernetes配置文件

你需要编写几个YAML文件来定义MySQL的部署。

a. 创建MySQL Deployment

创建一个名为mysql-deployment.yaml的文件,内容如下:

【yaml】

apiVersion: apps/v1

kind: Deployment

metadata:

name: mysql-deployment

spec:

replicas: 1

selector:

matchLabels:

app: mysql

template:

metadata:

labels:

app: mysql

spec:

containers:

  • name: mysql

image: mysql:latest

env:

  • name: MYSQL_ROOT_PASSWORD

value: your_password_here # 替换为你的MySQL root密码

ports:

  • containerPort: 3306

volumeMounts:

  • name: mysql-data

mountPath: /var/lib/mysql

volumes:

  • name: mysql-data

emptyDir: {} # 使用emptyDir作为临时存储,生产环境建议使用Persistent Volume

注意:emptyDir仅适用于测试或开发环境,因为它在Pod被删除时会丢失数据。生产环境中应使用Persistent Volume。

b. 创建MySQL Service

创建一个名为mysql-service.yaml的文件,内容如下:

【yaml】

apiVersion: v1

kind: Service

metadata:

name: mysql-service

spec:

selector:

app: mysql

ports:

  • protocol: TCP

port: 3306

targetPort: 3306

clusterIP: None # 如果需要ClusterIP类型的Service,则移除这一行

如果你不需要ClusterIP类型的Service(例如,如果你只从Pod内部访问MySQL),可以使用ClusterIP: None来创建一个Headless Service,这通常与StatefulSet一起使用以实现更高级的状态管理。

c. (可选)创建Persistent Volume和Persistent Volume Claim

为了在生产环境中持久存储MySQL数据,你需要创建Persistent Volume(PV)和Persistent Volume Claim(PVC)。

pv.yaml示例:

【yaml】

apiVersion: v1

kind: PersistentVolume

metadata:

name: mysql-pv

spec:

capacity:

storage: 10Gi

accessModes:

  • ReadWriteOnce

persistentVolumeReclaimPolicy: Retain

nfs:

path: /path/to/nfs/share # 替换为你的NFS路径

server: nfs-server.example.com # 替换为你的NFS服务器地址

pvc.yaml示例:

【yaml】

apiVersion: v1

kind: PersistentVolumeClaim

metadata:

name: mysql-pvc

spec:

accessModes:

  • ReadWriteOnce

resources:

requests:

storage: 10Gi

在mysql-deployment.yaml中,将emptyDir替换为PVC引用:

【yaml】

volumeMounts:

  • name: mysql-data

mountPath: /var/lib/mysql

volumes:

  • name: mysql-data

persistentVolumeClaim:

claimName: mysql-pvc

  1. 应用Kubernetes配置

使用kubectl命令应用上述YAML文件:

【bash】

kubectl apply -f mysql-deployment.yaml

kubectl apply -f mysql-service.yaml

如果你创建了PV和PVC,也需要应用它们

kubectl apply -f pv.yaml

kubectl apply -f pvc.yaml

  1. 验证部署

你可以使用以下命令查看Pod和服务是否成功创建:

【bash】

kubectl get pods

kubectl get services

你还可以使用kubectl logs命令查看MySQL Pod的日志,确保MySQL服务正在运行。

【bash】

kubectl logs

注意事项

• 在生产环境中,请确保使用强密码并配置适当的MySQL用户权限。

• 使用Persistent Volume来持久存储MySQL数据。

• 考虑使用StatefulSet来部署MySQL,以实现更好的状态管理和Pod重新调度。

• 监控MySQL的性能和资源使用情况,确保集群的稳定性和性能。

相关推荐
Lx3523 小时前
排序缓冲区调优:sort_buffer_size的合理配置
sql·mysql·性能优化
退役小学生呀9 天前
三、kubectl使用详解
云原生·容器·kubernetes·k8s
feifeigo1239 天前
Java 正则表达式高级用法
java·mysql·正则表达式
敏叔V5879 天前
大模型Text2SQL之在CentOS上使用yum安装与使用MySQL
linux·mysql·centos
程序员小潘9 天前
Kubernetes多容器Pod实战
云原生·容器·kubernetes
进击的码码码码N9 天前
Docker 镜像加速
运维·docker·容器
程序猿小D9 天前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+Vue实现的校园二手交易平台管理系统,推荐!
java·数据库·mysql·spring·vue·毕业设计·校园二手交易平台
张太行_9 天前
MySQL与Excel比较
数据库·mysql·excel
Q_w77429 天前
基于 Docker 的服务部署探索(Day 2)
运维·docker·容器
斯普信专业组9 天前
MySQL 8.x配置MGR高可用+ProxySQL读写分离(二):ProxySQL配置MySQL代理及读写分离
数据库·mysql