1、在kubernetes.io创建k8s集群访问应用Scale 增删副本,滚动更新
AWS、Azure、Google、阿里云、腾讯云等主流公有云提供的是基于 Kubernetes 的容器服务;Rancher、CoreOS、IBM、Mirantis、Oracle、Red Hat、VMWare 等无数厂商也在大力研发和推广基于 Kubernetes 的容器 CaaS 或 PaaS 产品。可以说,Kubernetes 是当前容器行业最炙手可热的明星。kubernetes.io 开发了一
AWS、Azure、Google、阿里云、腾讯云等主流公有云提供的是基于 Kubernetes 的容器服务;Rancher、CoreOS、IBM、Mirantis、Oracle、Red Hat、VMWare 等无数厂商也在大力研发和推广基于 Kubernetes 的容器 CaaS 或 PaaS 产品。可以说,Kubernetes 是当前容器行业最炙手可热的明星。
kubernetes.io 开发了一个交互式教程,通过 Web 浏览器就能使用预先部署好的一个 kubernetes 集群,快速体验 kubernetes 的功能和应用场景
打开 https://kubernetes.io/docs/tutorials/kubernetes-basics/
页面左边就能看到教程菜单:
指引大家完成创建 kubernetes 集群、部署应用、访问应用、扩展应用、更新应用等最常见的使用场景,迅速建立感性认识。
创建 Kubernetes 集群
点击教程菜单 1. Create a Cluster
-> Interactive Tutorial - Creating a Cluster
显示操作界面
左边部分是操作说明,右边是 Terminal,命令终端窗口。
按照操作说明,我们在 Terminal 中执行 minikube start
,然后执行 kubectl get nodes
,这样就创建好了一个单节点的 kubernetes 集群。
集群的唯一节点为 host01
,需要注意的是当前执行命令的地方并不是 host01
。我们是在通过 Kubernetes 的命令行工具 kubectl
远程管理集群
执行 kubectl cluster-info
查看集群信息:
heapster
、kubernetes-dashboard
都是集群中运行的服务。
部署应用
执行命令:
kubectl run kubernetes-bootcamp \
--image=docker.io/jocatalin/kubernetes-bootcamp:v1 \
--port=8080
通过 kubectl run
部署了一个应用,命名为 kubernetes-bootcamp
。
Docker 镜像通过 --image
指定。
--port
设置应用对外服务的端口。
这里 deployment
是 Kubernetes 的术语,可以理解为应用
Kubernetes 还有一个重要术语 Pod
。
Pod 是容器的集合,通常会将紧密相关的一组容器放到一个 Pod 中,同一个 Pod 中的所有容器共享 IP 地址和 Port 空间,也就是说它们在一个 network namespace 中。
Pod 是 Kubernetes 调度的最小单位,同一 Pod 中的容器始终被一起调度。
运行 kubectl get pods
查看当前的 Pod。
kubernetes-bootcamp-390780338-q9p1t
就是应用的 Pod。
访问应用
默认情况下,所有 Pod 只能在集群内部访问。对于上面这个例子,要访问应用只能直接访问容器的 8080 端口。为了能够从外部访问应用,我们需要将容器的 8080 端口映射到节点的端口。
执行如下命令:
kubectl expose deployment/kubernetes-bootcamp \
--type="NodePort" \
--port 8080
执行命令 kubectl get services
可以查看应用被映射到节点的哪个端口。
这里有两个 service,可以将 service 暂时理解为端口映射
kubernetes
是默认的 service,暂时不用考虑。kubernetes-bootcamp
是我们应用的 service,8080 端口已经映射到 host01 的 32320 端口,端口号是随机分配的,可以执行如下命令访问应用:
curl host01:32320
Scale 应用
默认情况下应用只会运行一个副本,可以通过 kubectl get deployments
查看副本数。
执行如下命令将副本数增加到 3 个:
kubectl scale deployments/kubernetes-bootcamp --replicas=3
通过 kubectl get pods
也可以看到当前 Pod 也增加到 3 个。
通过 curl
访问应用,可以看到每次请求发送到不同的 Pod,三个副本轮询处理,这样就实现了负载均衡。
要 scale down 也很方便,执行命令:
kubectl scale deployments/kubernetes-bootcamp --replicas=2
其中一个副本被删除了。
滚动更新
当前应用使用的 image 版本为 v1,执行如下命令将其升级到 v2:
kubectl set image deployments/kubernetes-bootcamp kubernetes-bootcamp=jocatalin/kubernetes-bootcamp:v2
通过 kubectl get pods
可以观察滚动更新的过程:v1 的 Pod 被逐个删除,同时启动了新的 v2 Pod。更新完成后访问新版本应用。
如果要回退到 v1 版本也很容易,执行 kubectl rollout undo
命令:
kubectl rollout undo deployments/kubernetes-bootcamp
验证版本已经回退到 v1。
至此,我们已经通过官网的交互式教程快速体验了 Kubernetes 的功能和使用方法。教程其余章节将详细讨论 Kubernetes 的架构、典型的部署方法、容器编排能力、网络方案、监控方案,帮助大家全面掌握 Kubernetes 的核心技能。
更多推荐
所有评论(0)