京东如何从OpenStack迁移至Kubernetes

中国最大电商公司之一的京东,最近分享了自己通过Kubernetes对基于应用程序容器的基础架构进行革新,取代OpenStack托管的IaaS基础架构过程中所获得的经验。本次迁移同时涉及内部网络组件,借此可将资源利用率提高30%。

在采用应用程序容器技术之前,京东的基础架构部署经历了两个阶段:物理机(2004 – 2014)以及操作系统容器(2014 – 2016)。第一阶段主要使用手工管理的裸机硬件,但这一阶段遇到了很多问题,例如上线前的准备时间过长(从分配到应用程序上线约需要一周时间),缺乏隔离机制,资源利用率不足,调度机制不够灵活。计算机失败后往往需要花费数小时迁移应用,且缺乏自动缩放能力。工程团队针对日志收集、自动化部署、编译和打包,以及资源监视等常用任务开发了内部工具。

京东基础架构的第二阶段开始采用容器技术。当时使用了操作系统容器,这意味着需要将现有应用程序和部署架构整体迁入容器中。当时的容器可以看作是对他们原本采用的物理机进行精简后一种运行速度更快的“物理机”,并未采用已经完全成熟的“容器哲学”。

尽管如此,通过采用容器技术,他们已经在第二阶段从时间和资源的使用率方面获得了巨大的收益。当时他们使用OpenStack作为编排层,并使用nova Docker驱动实现容器的管理。该团队选择Docker作为自己的容器平台,并逐渐向其中增添新的功能。所有应用陆续迁移到容器中,借此将计算资源请求的实现时间从原本的一周缩短至几分钟。应用程序的平均部署密度和物理机的利用率提升了三倍。该团队还针对部署任务构建了统一的API,公司内部将其称之为JDOS(JD Datacenter Operating System)1.0。

他们基于OpenStack的平台通过一个群集承载了大约4000至10000个计算节点。截至2016年11月,京东团队共运行了将近150,000个容器。这个平台帮助他们顺利度过了两次大流量在线促销活动,包括2016年双十一活动,共完成大约3千万个订单。

在第二阶段迁移至容器技术后,该工程团队已经可以对部署架构进行改动,使用容器作为基本的部署单位。公司内部将其称之为JDOS 2.0。这个方法关注的并非基础架构本身的管理,而在于可感知应用程序的容器管理。他们的平台设计包含两个抽象:系统和应用程序。一个“系统”可包含多个“应用程序”,每个应用程序可包含多个提供相同服务的Pod。一个系统对应着一个Kubernetes名称空间。

其他组件还包括部署流程和容器化的DevOps工具,这些内容均部署在Kubernetes管理的平台上,此外还包括Gitlab、Jenkins、Logstash、Harbor、Elasticsearch,以及Prometheus。部署过程中,源代码和Dockerfile会被推送至代码库和Jenkins构建。Jenkins被配置为主从模式,其中从节点负责构建和打包应用程序,此外还有一个类似的节点负责构建容器映像。他们使用了Harbor这一开源的Docker注册表存储所创建的映像。

图片来源:http://blog.kubernetes.io/2017/02/inside-jd-com-shift-to-kubernetes-from-openstack.html

为了在Kubelets和OpenStack Neutron之间实现更好的集成,京东根据Container Networking Interface标准自行开发了一个名为Cane的解决方案。在创建、删除或修改Kubernetes负载均衡器后,Cane可以通知Neutron负载均衡即服务(LBaaS)系统。此外他们通过在Cane内部运行的Hades组件为Pod提供内部的DNS解析服务。

 

  

本文转自d1net(转载)

时间: 2024-10-26 13:32:28

京东如何从OpenStack迁移至Kubernetes的相关文章

GitHub是如何无缝迁移到Kubernetes的?

本文讲的是GitHub是如何无缝迁移到Kubernetes的?[编者的话]全球最大的代码托管和编程社交网络GitHub,近期已经在开发.SRE等团队的配合下将服务切换到Kubernetes,因为其坐拥千万用户和亿级代码仓库,这可不是一个小工程,文章介绍了GitHub迁移到Kubernetes的整个过程. [3 天烧脑式基于Docker的CI/CD实战训练营 | 北京站]本次培训围绕基于Docker的CI/CD实战展开,具体内容包括:持续集成与持续交付(CI/CD)概览:持续集成系统介绍:客户端与

OpenStack 宣布用 Kubernetes 重写底层编排引擎

Mirantis是OpenStack的主要贡献者,今天他宣布将使用Kubernetes作为底层编排引擎重写其私有云平台.我们认为这是推进OpenStack和Kubernetes 社区伟大的一步. Openstack的用户将会享受到Kubernetes带来的巨大的效率.可管理性与弹性的提升,同时他们的应用将能够使用更多的云原生模式. 在一个平台上管理基于容器与虚拟机的应用也让Kubernetes社区更加有信心. 云原生路径 谷歌花了十几年时间开发.应用和提炼云原生计算的原则.云原生应用是: ● 容

openstack迁移的问题

问题描述 迁移需要服务器之间共享镜像,当双方服务器存放镜像的目录相同时,例如NFS共享就会覆盖本机的目录.有什么好的方法能不影响迁移目标的那台服务器?

京东大规模容器集群之 kubernetes 实践

01 容器时代已经到来 当前,容器的占有率可能比想象中还要快地增长,这个是使用 Docker 镜像的受欢迎的程度,可以看到几个排在前面的.然后平均一个公司有多少容器在跑,只有 7 个.但是在 06 年的时候,5 个都不到,其实增长还蛮快. 我觉得这个图挺有意思的,讲的是一个容器的平均生命周期,比较的是容器和未来的生命周期,容器的平均生命周期是 2.5 天,VM 是 23 天,这 2.5 天里面分了两部分,一部分是用了编排,一部分没有用编排.如果用户没有用 K8S 工具,平均的容器生命周期是一天,

OpenStack拥抱Kubernetes,双赢的举措

本文讲的是OpenStack拥抱Kubernetes,双赢的举措[编者的话]本文作者分析了OpenStack拥抱Kubernetes之后,能给两个社区带来什么. 就在今天,Mirantis,OpenStack的重要贡献者,宣布将使用Kubernetes作为其基础设施的编排引擎,并因此重构原有的私有云平台.我们认为这个举动将会使OpenStack和Kubernetes社区共同向前迈出一大步.随着Kubernetes的加入,OpenStack用户将从中获得更大的资源使用效率,可管理能力以及灵活性,并

Mirantis使用Kubernetes容器化OpenStack以缓解运维挑战

本文讲的是Mirantis使用Kubernetes容器化OpenStack以缓解运维挑战[编者的话]Swapnil是印度著名的记者和作家,其领域横跨Linux和开源软件.同时他也是印度有名的科幻作家.本文是他采访Mirantis公司关于Kubernetes融合OpenStack方面的实践. 经过诸如AT&T.Verizon.BMW.Volkswagen and Walmart等巨头的持续治理,OpenStach正快速成为一个核心建造组件,以帮助那些正在构建以私有云为基础设施的公司.当部署Open

OpenStack与Kubernetes融合

如果你想使用Kubernetes来构建你的应用程序环境,通过OpenStack来部署Kubernetes其架构是一种推荐的方式,本文将与大家分享Kubernetes在OpenStack上的编排方式与其优化方法. 以下介绍5种针对Kubernetes的调优方式,希望对大家有所帮助. 接下来让我们从架构分析开始,了解为什么需要这样的架构存在,解决什么样的问题.接着了解优化的目的,我们深入探讨几个优化方式与选项.结合部分实际案例或测试来优化后的改善.最后探讨后续发展与计划. 架构分析 容器的存在是为了

红帽谈基于OpenStack和Kubernetes的容器管理的未来

本文讲的是红帽谈基于OpenStack和Kubernetes的容器管理的未来,[编者的话]OpenStack是搭建私有云平台的事实标准:而Kubernetes作为谷歌集群管理系统Borg的开源版本,在容器集群管理方面前景光明.本文重点介绍了红帽在深度整合OpenStack和Kubernetes的尝试. 这个星期,在波特兰召开的OSCON 2015会议上,我们同谷歌以及其他成员一起庆祝了Kubernetes 1.0的发布以及CNCF(Cloud Native Computing Foundatio

基于OpenStack和Kubernetes的容器管理未来

[原文编者的话] OpenStack是搭建私有云平台的事实标准;而Kubernetes作为谷歌集群管理系统Borg的开源版本,在容器集群管理方面前景光明.本文重点介绍了红帽在深度整合OpenStack和Kubernetes的尝试. 这个星期,在波特兰召开的OSCON 2015会议上,我们同谷歌以及其他成员一起庆祝了Kubernetes 1.0的发布以及CNCF(Cloud Native Computing Foundation)基金会的建立.其中,红帽.谷歌和其他一些公司都是CNCF基金会的创始