上篇文章《Docker和Kubernetes安装》介绍了Docker for Mac的安装过程,接下来本章主要讲解MySQL pod的创建过程。k8s提供了emptyDirhostPathrbdcephfs等存储方式供容器使用,这些存储方式都有一个问题:开发人员必须得知指定存储的相关配置信息,才能使用存储。对此,k8s提供了两个新的API资源:

  1. PV(PersistentVolume)是管理员已经提供好的一块存储。在k8s集群中,PV像Node一样,是一个资源
  2. PVC(PersistentVolumeClaim)是用户对PV的一次申请。PVC对于PV就像Pod对于Node一样,Pod可以申请CPUMemory资源,而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

Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐