微服务架构从入门到精通之DevOps实践篇(三) Kubernetes上MySQL安装
上篇文章《Docker和Kubernetes安装》介绍了Docker for Mac的安装过程,接下来本章主要讲解MySQL pod的创建过程。k8s提供了emptyDir、hostPath、rbd、cephfs等存储方式供容器使用,这些存储方式都有一个问题:开发人员必须得知指定存储的相关配置信息,才能使用存储。对此,k8s提供了两个新的API资源:PV(PersistentVol..
上篇文章《Docker和Kubernetes安装》介绍了Docker for Mac的安装过程,接下来本章主要讲解MySQL pod的创建过程。k8s提供了emptyDir、hostPath、rbd、cephfs等存储方式供容器使用,这些存储方式都有一个问题:开发人员必须得知指定存储的相关配置信息,才能使用存储。对此,k8s提供了两个新的API资源:
- PV(PersistentVolume)是管理员已经提供好的一块存储。在k8s集群中,PV像Node一样,是一个资源
- PVC(PersistentVolumeClaim)是用户对PV的一次申请。PVC对于PV就像Pod对于Node一样,Pod可以申请CPU和Memory资源,而PVC也可以申请PV的大小与权限
有了PersistentVolumeClaim,用户只需要告诉Kubernetes需要什么样的存储资源,而不必关心真正的空间从哪里分配,如何访问等底层细节信息;这些Storage Provider的底层信息交给管理员来处理,只有管理员才应该关心创建PV的细节信息。
1.1 PV的配置文件mysql-pv.yaml
apiVersion: v1
kind: PersistentVolume
metadata:
name: mysql-pv
spec:
accessModes:
- ReadWriteOnce
capacity:
storage: 1Gi
persistentVolumeReclaimPolicy: Retain
hostPath:
path: /Users/zhuxihua/mysql/data
1.2 PVC的配置文件mysql-pvc.yaml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: mysql-pvc
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 1Gi
1.3 创建mysql配置文件
apiVersion: v1
kind: Service
metadata:
name: mysql
spec:
ports:
- port: 3306
selector:
app: mysql
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: mysql
spec:
replicas: 1
selector:
matchLabels:
app: mysql
template:
metadata:
labels:
app: mysql
spec:
containers:
- name: mysql
image: mysql:5.6
env:
- name: MYSQL_ROOT_PASSWORD
value: password
ports:
- containerPort: 3306
name: mysql
volumeMounts:
- name: mysql-persistent-storage
mountPath: /var/lib/mysql
volumes:
- name: mysql-persistent-storage
persistentVolumeClaim:
claimName: mysql-pvc
1.4创建mysql service和pod
$ kubectl create -f mysql-pv.yaml
$ kubectl create -f mysq-pvc.yaml
$ kubectl create -f mysq.yaml
$ kubectl get nodes
$ kubectl get pod
目前采用的是NodePort方式,通过本地可视化工具可以进行连接,端口使用的是对外暴露的nodePort,如果采用ClusterIP,则需要开启proxy:
kubectl proxy --port=8888
1.5 查看MySQL Pod
注意一点的是现在我们采用容器间相互通讯,所有的网络通讯是在docker所划分的整个网络中,故mysql数据库的地址也必须是docker网络子网中给mysql分配的一个有效IP地址,可以通过查看mysql这个pod的详情进行查看所属IP,命令如下:
$ kubectl describe pod mysql
更多推荐
所有评论(0)