概述
本文将介绍如何基于 Kubernetes 部署 MySQL 数据库。
创建服务 Service
创建一个 Service 为即将部署的 MySQL 数据库固定连接的 IP,同时提供负载均衡,下面是 mysql-service.yaml 文件的内容:
apiVersion: v1
kind: Service
metadata:
name: mysql
spec:
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: 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
登录后复制
部署 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
登录后复制
推荐学习:《mysql视频教程》
以上就是Kubernetes是什么?如何基于它部署MySQL数据库的详细内容,更多请关注靠谱客其它相关文章!
最后
以上就是霸气帽子为你收集整理的Kubernetes是什么?如何基于它部署MySQL数据库的全部内容,希望文章能够帮你解决Kubernetes是什么?如何基于它部署MySQL数据库所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复