版本
根据参考资料1,2,下载 docker desktop 后,开启 Kubernetes 服务。当前版本为2.3.0.4, Kubernetes 为 v1.16.5。
通过 kubectl get nodes
命令可以看到节点情况,这里只有一个Master节点。
准备工作
创建一个单独的目录,来存放案例所需的文件
mkdir k8s-demo && cd k8s-demo
构建镜像
这里直接用名docker pull tomcat
下载 tomcat,需要对tomcat 镜像进行修改才
可以访问,详见文章docker安装tomcat启动后,访问首页出现404
最终,我们得到了一个标签 (版本) 为 mytomcat的tomcat镜像。
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
使用 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
查看服务,可以指定服务名。
端口号是 k8s 随机分配的,在这里,访问 http://127.0.0.1:30706/,就会被转发到 k8s-tomcat-svc 服务的8080端口。
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
创建
使用kubectl get deployments
命令,可以查看副本集情况。
参考资料
- Docker Desktop启动Kubernetes
- 手把手带你玩转k8s-win10上搭建k8s集群
- Kubernetes基础:Deployments从beta版本到v1的变化对应方法