08 部署博客应用

StatefulSet 部署 MySQL

在 node1 节点

  1. 在 node 节点安装 MySQL yum install mysql -y

  2. 部署 MySQL StatefulSet

    • /tmp 目录下创建 mysql 文件夹

    • cd ~

    • vim 11-1-mysql.yaml

    • apiVersion: v1
      kind: Service
      metadata:
        name: mysql57
        labels:
          app: mysql
      spec:
        ports:
        - port: 3306
          name: mysql
          nodePort: 30306
        type: NodePort
        selector:
          app: mysql
      ---
      apiVersion: apps/v1
      kind: StatefulSet
      metadata:
        name: mysql
      spec:
        selector:
          matchLabels:
            app: mysql 
        serviceName: "mysql"
        replicas: 1 
        template:
          metadata:
            labels:
              app: mysql 
          spec:
            terminationGracePeriodSeconds: 10
            containers:
            - name: mysql
              image: registry.cn-beijing.aliyuncs.com/qingfeng666/mysql:5.7
              ports:
              - containerPort: 3306
                name: mysql
              volumeMounts:
              - name: host-path
                mountPath: /var/lib/mysql
              env:
                - name: MYSQL_ROOT_PASSWORD
                  value: "password"
            volumes:
              - name: host-path
                hostPath:
                    path: /tmp/mysql
                    type: DirectoryOrCreate
      
    • 创建 kubectl create -f 11-1-mysql.yaml

    • kubectl get po 可以看到:

    • NAME      READY   STATUS              RESTARTS   AGE
      mysql-0   0/1     ContainerCreating   0          19
      
  3. 初始化 MySQL

    mysql -uroot -P30306 -h127.0.0.1 -ppassword
    

    可以看到

    Welcome to the MariaDB monitor.  Commands end with ; or \g.
    Your MySQL connection id is 2
    Server version: 5.7.32 MySQL Community Server (GPL)
    
    Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
    
    Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
    
    MySQL [(none)]>
    
  1. 创建数据库

    create database blogDB DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
    
    MySQL [(none)]> create database blogDB DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
    Query OK, 1 row affected (0.01 sec)
    MySQL [(none)]> show databases;
    +--------------------+
    | Database           |
    +--------------------+
    | information_schema |
    | blogDB             |
    | mysql              |
    | performance_schema |
    | sys                |
    +--------------------+
    5 rows in set (0.01 sec)
    
    MySQL [(none)]> exit
    Bye
    

删除

cd ~
kubectl delete -f 11-1-mysql.yaml

查看

kubectl get po

可以看到

No resources found in default namespace.

重新创建

kubectl create -f 11-1-mysql.yaml

启动数据库

mysql -uroot -P30306 -h127.0.0.1 -ppassword

查看数据库

show databases;

可以看到之前创建的数据库 blogDB 还在

编写应用的 Service, Deployment 文件

在 node1 节点

vim 11-2-blog.yaml
apiVersion: v1
kind: Service
metadata:
  name: kubeblog
spec:
  selector:
    app: kubeblog
  type: NodePort
  ports:
  - port: 5000
    targetPort: 5000
    nodePort: 30002
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: kubeblog
spec:
  selector:
    matchLabels:
      app: kubeblog
  template:
    metadata:
      labels:
        app: kubeblog
    spec:
      containers:
      - name: kubeblog
        image: registry.cn-beijing.aliyuncs.com/qingfeng666/kubeblog:1.3
        resources:
          limits:
            memory: "512Mi"
            cpu: "500m"
        ports:
        - containerPort: 5000
        env:
          - name: MYSQL_PORT
            value: "30306"
          - name: MYSQL_SERVER
            value: "192.168.190.132"

kubectl create -f 11-2-blog.yaml
kubectl get po
NAME                        READY   STATUS    RESTARTS   AGE
kubeblog-866b655bdf-v879f   1/1     Running   0          35s
mysql-0                     1/1     Running   0          14m
kubectl get svc
NAME         TYPE        CLUSTER-IP    EXTERNAL-IP   PORT(S)          AGE
kubeblog     NodePort    10.1.190.56   <none>        5000:30002/TCP   107s
kubernetes   ClusterIP   10.1.0.1      <none>        443/TCP          15d
mysql57      NodePort    10.1.96.16    <none>        3306:30306/TCP   15m

稍等一会,等待服务启动

浏览器访问

http://192.168.190.132:30002/

可以访问到博客应用

使用私有镜像中心拉取镜像

在 master 节点

启动镜像中心

docker start artifactory-jcr

配置 vim /etc/docker/daemon.json

{
"registry-mirrors": ["https://registry.docker-cn.com",
"https://dockerhub.azk8s.cn",
"https://reg-mirror.qiniu.com",
"http://hub-mirror.c.163.com",
"https://docker.mirrors.ustc.edu.cn"
],
"insecure-registries": ["art.local:8081","192.168.190.131:8081"]
}

重启 docker 和 kubelet

systemctl restart docker
systemctl restart kubelet

查看

docker info

可以看到

Labels:
 Experimental: false
 Insecure Registries:
  192.168.190.131:8081
  art.local:8081
  127.0.0.0/8

推送镜像到镜像中心(上一篇已推送)

创建镜像仓库秘钥

kubectl create secret docker-registry regcred-local --docker-server=192.168.190.131:8081 --docker-username=admin --docker-password=password123 --docker-email=test@163.com

拉取镜像,在 master 节点或者 node 节点都可以。这里是在 node1 节点。

vim 11-3-regsecret.yaml
apiVersion: v1
kind: Service
metadata:
  name: kubeblog
spec:
  selector:
    app: kubeblog
  type: NodePort
  ports:
  - port: 5000
    targetPort: 5000
    nodePort: 30002
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: kubeblog
spec:
  selector:
    matchLabels:
      app: kubeblog
  template:
    metadata:
      labels:
        app: kubeblog
    spec:
      hostAliases:
      - ip: "192.168.190.131"
        hostnames:
        - "art.local"
      containers:
      - name: kubeblog
        image: 192.168.190.131:8081/docker-local/kubeblog:1.0
        resources:
          limits:
            memory: "512Mi"
            cpu: "500m"
        ports:
        - containerPort: 5000
        env:
          - name: MYSQL_PORT
            value: "30306"
          - name: MYSQL_SERVER
            value: "192.168.190.132"
      imagePullSecrets:
      - name: regcred-local
      

为博客应用进行配置分离

在 master 节点,创建 MySQL 秘钥 secret

kubectl create secret generic mysql-password-test --from-literal=MYSQL_PASSWORD_TEST=password

可以看到

secret/mysql-password-test created

在 node1 节点,登录 MySQL

mysql -h192.168.190.132 -uroot -P30306 -ppassword

创建数据库

create database blogDBTest default charset utf8mb4;

在 master 节点,在 Deployment 使用该秘钥

vim 11-4.yaml
apiVersion: v1
kind: Service
metadata:
  name: kubeblog
spec:
  selector:
    app: kubeblog
  type: NodePort
  ports:
  - port: 5000
    targetPort: 5000
    nodePort: 30002
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: kubeblog
spec:
  selector:
    matchLabels:
      app: kubeblog
  template:
    metadata:
      labels:
        app: kubeblog
    spec:
      hostAliases:
      - ip: "192.168.190.131"
        hostnames:
        - "art.local"
      containers:
      - name: kubeblog
        image: 192.168.190.131:8081/docker-local/kubeblog:1.1
        ports:
        - containerPort: 5000
        env:
          - name: MYSQL_PORT
            value: "30306"
          - name: MYSQL_SERVER
            value: "192.168.190.132"
          - name: MYSQL_DB_NAME
            value: "blogDBTest"
          - name: MYSQL_USER_TEST
            value: "root"
          - name: MYSQL_PASSWORD_TEST
            valueFrom:
                secretKeyRef:
                  name: mysql-password-test
                  key: MYSQL_PASSWORD_TEST
      imagePullSecrets:
      - name: regcred-local
kubectl create -f 11-4.yaml 

空间隔离和镜像晋级

查看命名空间

kubectl get ns

创建 test 和 prod 命名空间

kubectl create namespace test
kubectl create namespace prod

创建测试环境的秘钥

kubectl create secret generic mysql-password-test --from-literal=MYSQL_PASSWORD_TEST=password -n test

查看测试环境的秘钥

kubectl get secret -n test

可以看到

NAME                  TYPE                                  DATA   AGE
default-token-lwmdv   kubernetes.io/service-account-token   3      3m2s
mysql-password-test   Opaque                                1      37s

创建测试环境的镜像仓库秘钥

kubectl create secret docker-registry regcred-local --docker-server=192.168.190.131:8081 --docker-username=admin --docker-password=password123 --docker-email=test@163.com -n test

再查看一下测试环境的秘钥

kubectl get secret -n test

可以看到

NAME                  TYPE                                  DATA   AGE
default-token-lwmdv   kubernetes.io/service-account-token   3      6m3s
mysql-password-test   Opaque                                1      3m38s
regcred-local         kubernetes.io/dockerconfigjson        1      3s
vim 11-5-namespace.yaml
apiVersion: v1
kind: Service
metadata:
  name: kubeblog
  namespace: test
spec:
  selector:
    app: kubeblog
  type: NodePort
  ports:
  - port: 5000
    targetPort: 5000
    nodePort: 30002
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: kubeblog
  namespace: test
spec:
  selector:
    matchLabels:
      app: kubeblog
  template:
    metadata:
      labels:
        app: kubeblog
    spec:
      hostAliases:
      - ip: "192.168.190.131"
        hostnames:
        - "art.local"
      containers:
      - name: kubeblog
        image: 192.168.190.131:8081/docker/kubeblog:1.1
        ports:
        - containerPort: 5000
        env:
          - name: MYSQL_PORT
            value: "30306"
          - name: MYSQL_SERVER
            value: "192.168.190.132"
          - name: MYSQL_DB_NAME
            value: "blogDBTest"
          - name: MYSQL_USER_TEST
            value: "root"
          - name: MYSQL_PASSWORD_TEST
            valueFrom:
                secretKeyRef:
                  name: mysql-password-test
                  key: MYSQL_PASSWORD_TEST
      imagePullSecrets:
      - name: regcred-local
kubectl create -f 11-5-namespace.yaml
kubectl get po
NAME      READY   STATUS    RESTARTS   AGE
mysql-0   1/1     Running   3          5d3h
kubectl get po -n test
NAME                        READY   STATUS    RESTARTS   AGE
kubeblog-747688d947-zggcl   1/1     Running   0          14m

浏览器访问:http://192.168.190.132:30002/

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

推荐阅读更多精彩内容