真正的生产型应用会涉及多个容器,这些容器必须跨多个服务器主机进行部署。 Kubernetes可以提供用户所需的编排和管理功能,以便用户针对这些工作负载进行大规模容器部署。 借助Kubernetes编排功能,用户可以构建多个容器的应用服务,跨集群调度、扩展这些容器,并长期持续管理这些容器的健康状况 。
一、Kubernetes概述
Kubernetes站在Borg(Borg是谷歌的一个久负盛名的内部使用的大规模集群管理系统,它基于容器技术,目的是实现资源管理的自动化,以及跨多个数据中心的资源利用率的最大化。)这个前辈的肩膀上,汲取了Borg过去十年间的经验与教训,Kubernetes里面有很多先进的设计理念,一经开源就一鸣惊人,并迅速称霸容器领域。2015 年7月Google公司正式对外发布了Kubernetes v1.0,意味着这个开源容器编排系统可以正式在生产环境中使用 。
使用Kubernetes有如下明显优势 : Kubernetes提供了一个便捷、有效的PaaS平台,让用户可以在物理机和虚拟机集群上调用和运行容器,可以帮助用户在生产环境中完全实施并依托基于容器的基础架构运营 。 由于Kubernetes的实质在于实现操作任务自动化,所以用户可以将其他应用平台或管理系统分配给用户的许多相同的任务交给容器来执行 。
目前,Kubernetes已经成为了容器编排领域的事实标准,国内的很多公司,如阿里、字节、腾讯等知名企业也都在使用Kubernetes进行应用的容器化改造,构建企业的容器云平台。
二、Kubernetes能做什么?
Kubernetes是一个全新的基于容器技术的分布式架构解决方案,并且是一个一站式的完备的分布式系统开发和支撑平台。Kubernetes为用户提供了以下功能:
- 服务发现和负载均衡:Kubernetes可以使用DNS名称或自己的IP地址公开容器,如果进入容器的流量很大, Kubernetes可以负载均衡并分配网络流量,从而使部署稳定。
- 存储编排:Kubernetes允许你自动挂载你选择的存储系统,例如本地存储、公共云提供商等。
- 自动部署和回滚:你可以使用Kubernetes描述已部署容器的所需状态,它可以以受控的速率将实际状态更改为期望状态。例如,你可以自动化Kubernetes来为你的部署创建新容器, 删除现有容器并将它们的所有资源用于新容器。
- 自动完成装箱计算:Kubernetes允许你指定每个容器所需CPU和内存(RAM)。 当容器指定了资源请求时,Kubernetes可以做出更好的决策来管理容器的资源。
- 自我修复:Kubernetes重新启动失败的容器、替换容器、杀死不响应用户定义的运行状况检查的容器,并且在准备好服务之前不将其通告给客户端。
- 密钥与配置管理:Kubernetes允许你存储和管理敏感信息,例如密码、OAuth令牌和ssh密钥。 你可以在不重建容器镜像的情况下部署和更新密钥和应用程序配置,也无需在堆栈配置中暴露密钥。