版本

根据参考资料1,2,下载 docker desktop 后,开启 Kubernetes 服务。当前版本为2.3.0.4, Kubernetes 为 v1.16.5。

kuboard k8s部署nginx configMap k8s部署tomcat_tomcat


通过 kubectl get nodes 命令可以看到节点情况,这里只有一个Master节点。

kuboard k8s部署nginx configMap k8s部署tomcat_tomcat_02

准备工作

创建一个单独的目录,来存放案例所需的文件

mkdir k8s-demo && cd k8s-demo

构建镜像

这里直接用名docker pull tomcat 下载 tomcat,需要对tomcat 镜像进行修改才
可以访问,详见文章docker安装tomcat启动后,访问首页出现404

最终,我们得到了一个标签 (版本) 为 mytomcat的tomcat镜像。

kuboard k8s部署nginx configMap k8s部署tomcat_tomcat_03

Pod

Pod 是 k8s 里面基本的部署调度单元,每个 Pod 可以由一个或多个容器组成,容器之间共享存储、网络等资源。
在 k8s 里面最小的部署单元不是容器而是 Pod,所以需要把 tomcat容器 转成 Pod 对象,再交由 k8s 创建。

创建pod.yaml 文件,内容如下:

apiVersion: v1
kind: Pod
metadata:
  name: k8s-tomcat
  labels:
    app: k8s
spec:
  containers:
    - name: k8s-tomcat
      image: tomcat:mytomcat
      ports:
        - containerPort: 8080
  • apiVersion。API 版本号,这个版本号需要根据我们安装的 k8s 版本和资源对象类型变化,不是固定的
  • kind。描述对象的类型,不同的对象类型肯定不一样 ,如 Pod、 Deployment、Service、Job、Ingress 等。
  • metadata。定义元数据,用于唯一识别对象的数据。常用的配置项如 name (名字)、namespace (命令空间)、labels (标签) 等
  • spec。规格声明,描述了某一个实体的期望状态,常用项如 containers、storage、volumes、template 等。在这里配置的容器名字为k8s-tomcat,使用之前构建的tomcat:mytomcat 作为镜像,容器可被访问的端口是 8080

使用 kubectl create -f pod.yaml 命令创建Pod

kuboard k8s部署nginx configMap k8s部署tomcat_Pod_04

使用 kubectl get pods命令可以查看Pod状态

Service

Pod 一般是不能从外部直接访问的。这里要用需要创建一个服务 (Service)。Service 的作用主要是做反向代理 (Reverse Proxy) 和负载均衡 (LB),负责把请求分发给后面的 Pod。

创建 svc.yaml 文件,内容如下:

apiVersion: v1
kind: Service
metadata:
  name: k8s-tomcat-svc
spec:
  selector:
    app: k8s
  type: NodePort
  ports:
    - protocol: TCP
      port: 8080
      targetPort: 8080
  • 资源类型 kind 是 Service
  • 服务名字k8s-tomcat-svc
  • spec.selector 指定请求会被发送给集群里的哪些 Pod,一般是用标签选择,app:k8s 在上面的 pod.yaml 里面指定了,所以这个服务会把流量发送给 k8s-tomcat 这个 Pod
  • spec.type 指定服务暴露方式,这里是 NodePort,Master 会从由启动参数配置的范围 (默认是 30000-32767) 中分配一个端口,然后每一个 Node 都会将这个端口代理到你的 Service。。其他还有 LoadBalancer、Ingress 等。

使用kubectl create -f svc.yaml创建服务,kubectl get svc 查看服务,可以指定服务名。

kuboard k8s部署nginx configMap k8s部署tomcat_k8s_05

端口号是 k8s 随机分配的,在这里,访问 http://127.0.0.1:30706/,就会被转发到 k8s-tomcat-svc 服务的8080端口。

kuboard k8s部署nginx configMap k8s部署tomcat_demo_06

Deployment

Deployment 可以定义一组Pod期望数量,Controller会维持Pod数量与期望数量一致。在这里,我们使用Deployment 创建 Pod 的副本。

创建deployment.yaml文件,内容如下:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: k8s-tomcat-deployment
spec:
  replicas: 10
  minReadySeconds: 3
  strategy:
    type: RollingUpdate
    rollingUpdate:
      maxUnavailable: 1
      maxSurge: 1  
  selector:
    matchLabels:
        app: k8s
  template:
    metadata:
      labels:
        app: k8s
    spec:
      containers:
      - name: k8s-tomcat-pod
        image: tomcat:mytomcat
        ports:
        - containerPort: 80
  • 注意 apiVersion 的取值与pod.yaml的不同
  • spec.replicas 指定了这个 deployment 要有 10 个 Pod

使用命令kubectl create -f deployment.yaml创建

kuboard k8s部署nginx configMap k8s部署tomcat_demo_07

使用kubectl get deployments 命令,可以查看副本集情况。

kuboard k8s部署nginx configMap k8s部署tomcat_实践_08

参考资料

  1. Docker Desktop启动Kubernetes
  2. 手把手带你玩转k8s-win10上搭建k8s集群
  3. Kubernetes基础:Deployments从beta版本到v1的变化对应方法