Kubernetes 入门:运行有状态服务

本文以 WordPress 为例,演示在 Kubernetes 集群中运行有状态服务,以及相关命令和概念。

为 MYSQL 密码创建 Secret

Secret 是一个对象,存储一系列的敏感信息,比如 password 和 key。

创建 Secret 对象

kubectl create secret generic mysql-pass --from-literal=password=YOUR-PASSWORD

YOUR-PASSWORD 替换为你想实际应用的密码

查看 Secrets

kubectl get secrets
NAME                  TYPE                                  DATA      AGE
default-token-jdn58   kubernetes.io/service-account-token   3         1d
mysql-pass            Opaque                                1         6s

部署 MySQL

在 k8s 中,PersistentVolumeClaims(简称 PVC) 和 PersistentVolumes(简称PV) 用于数据的持久化存储。

  • PV:持久化卷,是集群的一部分。就像 Node 一样,属于集群中的资源。
  • PVC:用户对存储的请求。它与 Pod 相似,Pod 消耗 Node 资源,PVC 消耗 PV 资源。

1、新建 MySQL 部署文件 mysql-deployment.yaml

apiVersion: v1
kind: Service
metadata:
  name: wordpress-mysql
  labels:
    app: wordpress
spec:
  ports:
    - port: 3306
  selector:
    app: wordpress
    tier: mysql
  clusterIP: None
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysql-pv-claim
  labels:
    app: wordpress
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 10Gi
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: wordpress-mysql
  labels:
    app: wordpress
spec:
  selector:
    matchLabels:
      app: wordpress
      tier: mysql
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: wordpress
        tier: mysql
    spec:
      containers:
      - image: mysql:5.6
        name: mysql
        env:
        - name: MYSQL_ROOT_PASSWORD
          valueFrom:
            secretKeyRef:
              name: mysql-pass
              key: password
        ports:
        - containerPort: 3306
          name: mysql
        volumeMounts:
        - name: mysql-persistent-storage
          mountPath: /var/lib/mysql
      volumes:
      - name: mysql-persistent-storage
        persistentVolumeClaim:
          claimName: mysql-pv-claim

2、部署 MySQL

kubectl create -f mysql-deployment.yaml

3、确认 PersistentVolume 是动态配置的

kubectl get pvc
NAME             STATUS    VOLUME                                     CAPACITY   ACCESS MODES   STORAGECLASS   AGE
mysql-pv-claim   Bound     pvc-22264d66-543c-11e8-993e-080027736407   10Gi       RWO            standard       1m

4、确认 Pod 正常运行

kubectl get pod
NAME                               READY     STATUS    RESTARTS   AGE
wordpress-mysql-7ddd5d59dd-njv2b   1/1       Running   0          5m

部署 WordPress

和 MySQL 类似,WordPress 也需要创建 Deployment 和 Service ,也需要 PVC 做持久化存储、Secret 做密码保密,另外,WordPress 需要暴露给集群外部的流量使用,还需要配置 type: NodePort

1、创建 WordPress 部署文件 wordpress-deployment.yaml

apiVersion: v1
kind: Service
metadata:
  name: wordpress
  labels:
    app: wordpress
spec:
  ports:
    - port: 80
  selector:
    app: wordpress
    tier: frontend
  type: LoadBalancer
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: wp-pv-claim
  labels:
    app: wordpress
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 10Gi
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: wordpress
  labels:
    app: wordpress
spec:
  selector:
    matchLabels:
      app: wordpress
      tier: frontend
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: wordpress
        tier: frontend
    spec:
      containers:
      - image: registry.docker-cn.com/library/wordpress:4.8-apache
        name: wordpress
        env:
        - name: WORDPRESS_DB_HOST
          value: wordpress-mysql
        - name: WORDPRESS_DB_PASSWORD
          valueFrom:
            secretKeyRef:
              name: mysql-pass
              key: password
        ports:
        - containerPort: 80
          name: wordpress
        volumeMounts:
        - name: wordpress-persistent-storage
          mountPath: /var/www/html
      volumes:
      - name: wordpress-persistent-storage
        persistentVolumeClaim:
          claimName: wp-pv-claim

2、部署 WordPress

kubectl create -f wordpress-deployment.yaml

3、稍作等待,查看整个 WordPress 服务,可以看到 MySQL 和 WordPress 均正常工作

NAME                                   READY     STATUS    RESTARTS   AGE
pod/wordpress-5d7d6dfb58-mxr9k         1/1       Running   0          4m
pod/wordpress-mysql-7ddd5d59dd-njv2b   1/1       Running   0          24m

NAME                      TYPE           CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
service/kubernetes        ClusterIP      10.96.0.1       <none>        443/TCP        1d
service/wordpress         LoadBalancer   10.107.47.102   <pending>     80:30435/TCP   4m
service/wordpress-mysql   ClusterIP      None            <none>        3306/TCP       24m

NAME                              DESIRED   CURRENT   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/wordpress         1         1         1            1           4m
deployment.apps/wordpress-mysql   1         1         1            1           24m

NAME                                         DESIRED   CURRENT   READY     AGE
replicaset.apps/wordpress-5d7d6dfb58         1         1         1         4m
replicaset.apps/wordpress-mysql-7ddd5d59dd   1         1         1         24m

提醒: Minikube 只能通过 NodePort 暴露服务. EXTERNAL-IP 永远是 <pending>.

4、访问 WordPress

minikube service wordpress

移除 WordPress

删除 Secret

kubectl delete secret mysql-pass

删除 Deployment

kubectl delete deployment -l app=wordpress

删除 Service

kubectl delete service -l app=wordpress

删除 PVC

kubectl delete pvc -l app=wordpress

-l, --selector='': 选择器过滤, 不包含那些未初始化的.

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 161,513评论 4 369
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,312评论 1 305
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 111,124评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,529评论 0 217
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,937评论 3 295
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,913评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,084评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,816评论 0 205
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,593评论 1 249
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,788评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,267评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,601评论 3 261
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,265评论 3 241
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,158评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,953评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,066评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,852评论 2 277

推荐阅读更多精彩内容