本文源于时速云CEO黄启功的一次线上分享,主题为《容器云平台在企业中的落地实践》。文章主要从以下四个维度对Docker容器技术的发展及落地实践进行了分析和介绍,在此梳理,以飨各位。
Topic:
- 为什么Docker会这么火,它给我们带来了什么
- Docker容器云对目前云计算行业的影响
- 传统企业如何落地Docker容器技术
- 时速云某制造业客户如何借力容器技术打造新一代的云原生应用平台
以下为线上分享全文:
我们先来看第一个问题,为什么Docker会这么火,它给我们带来了什么?
Docker容器技术应该是近年来最火热的一个开源技术,它真正改变了企业应用从开发、构建到发布、运行的整个生命周期。
通俗的讲,Docker定义了一套应用从开发构建、部署以及运行的标准体系,它其实就像我们最早之前的集装箱的发明,它使得应用的交付管理变得非常简单。因为大家都知道,虚拟化是云计算的基石,其实基于容器技术的虚拟化改变了传统意义上的虚拟化,从而会对整个云计算产生了很深远的影响。
随着谷歌、亚马逊、微软,还有国内的BAT、华为等云计算厂商加入对Docker开源技术的投入,整个围绕Docker的市场其实被全面引爆了,出现了众多像时速云这样围绕容器技术的创业公司,以及生态圈。
据统计,截至今年年初,全球总共有将近50多万个应用已经Docker容器化,两年时间内,实现了3000%的增长,这一发展速度其实早已经超过了以前传统的像openstack等这些虚拟化技术。
基于Docker的容器服务,我们称之为CaaS,就是容器级服务,它涵盖了IaaS跟PaaS两者的优势,它其实是一种更轻量级的虚拟化,可以解决应用的部署、开发运维、微服务这些问题。
而且我觉得未来的SaaS也都将会容器化,因为容器比虚拟机更轻量灵活,而且能够更快的加速业务的交付,所以我认为,未来Docker对SaaS的交付也会带来一个质的改变。
Docker主要有以下几个应用场景:
- 开发运维,它打破了开发和运维之间的壁垒,提高了整个业务应用从开发、构建、部署、集成、运行等整个生命周期的效率。具体来讲,就是它会通过一个标准的Docker镜像作为应用的一个交付件;
- CI/CD,翻译成中文叫持续集成跟持续部署,它可以让开发人员快速的开发和测试应用,同时达到一个目的,就是让整个业务应用能够更快速的交付;
- 微服务,微服务相对于传统的单体结构,有非常多的好处。它能够把单体单块结构拆分成多个组件,每个组件运行在独立的容器内,这样对于容灾容错以及高并发都会有非常大的好处;
- 提高系统的资源利用率, Docker容器的运行不需要额外的hypervisor支持,它是内核级的虚拟化,可以实现更高的性能以及效率,这也是很多像传统的数据中心厂商看中Docker的一个原因。
其他的应用场景包括像混合云,比如中间件,SaaS应用,跟OpenStack的结合,以及数据中心这些都是比较典型的一些应用场景。
接下来我们看看第二个问题,Docker容器云对目前云计算行业的一个影响。
Docker作为新一代的云计算技术,其实在整个行业非常知名而且已经风靡全球,它为整个IT领域输出一个集装箱的概念,正如集装箱在运输领域的作用,它可以把原来一些非标准的东西统一放在一个集装箱里,让它能够加速整个运输的效率。
这正如我们的软件世界领域一样,就是说我们会把不同的软件架构,技术栈统一封装在一个以容器为单元的集装箱里去做管理跟运行,这样会大大提高我们整个软件交付的效率。
对于企业来说,通常希望产品具有两个特点:
- 快速交付,我们能够非常快速的响应市场或客户需求的变化;
- 业务能够永远在线,比如说面对用户爆发式的增长,以及频繁的软件更新,能够保证业务持续,不会被中断。
随着云计算的发展, SaaS已经解决了我们对计算资源,存储、网络这些基础设施的需求,我们开始对开发运维一体化、持续集成、持续交付、以及微服务等产生迫切需求。因为随着市场的变化,我们往往需要整个业务能够随着市场的变化实现快速交付,这样的需求会变得越来越迫切。
通过一种以应用为中心的新一代云平台,用户不需要关心资源的申请,软件的部署和安装,这种自动化的运维全部交给了云平台,可以真正让企业聚焦在自己的业务本身,所以这也是Docker给大家带来的便利,Docker的诞生其实在整个应用交付,以及在开发运维方面,都带来了一些实质的变化。
Docker容器云将会给整个虚拟化开发运维、微服务、持续集成与持续交付,传统的中间件以及我们的SaaS带来一个很深刻的变化。 我曾经说过,Docker将会成为主流,未来SaaS应用也基本上都会容器化。应用可以不再运行在一个固定的虚拟机中,而是以这种轻量级可扩展的容器为运行单元。
Docker会对目前的云计算行业造成一个冲击,比如我们可以看到现在OpenStack、OpenShift都在拥抱或者融合Docker,Docker同时也在打造自己的生态圈,比如说定义自己的基础设施,比如说我们可以看到有基于轻量级的操作系统,比如说CoreOS, rancher这样的公司出来,所以我们可以看到这是一个跟旧有的云计算行业相互融合、相互进步的一个方向。
我们认为Docker未来会出现一个爆发式的增长,而且越来越多的传统行业会拥抱Docker,然后利用基于Docker容器技术的PaaS云平台去加速业务应用的交付,继而实现业务的增长和创新。
第三个问题是传统企业如何落地Docker容器技术?
我们知道互联网创业都讲究痛点,做企业级市场也是一样,我们只有找到企业的痛点,然后很好的帮助客户去解决,然后客户才会愿意买单,目前企业在应用运维管理这些方面,主要面临以下几个方面的痛点:
- 应用迭代缓慢,业务交付经常被推迟;
- 传统的单体架构应用难以维护和扩展;
- 应用的运维管理比较复杂。
从时速云实际落地的客户案例来看,目前我们主要从开发运维、微服务、运维管理这几个角度去切入,然后针对企业如何落地Docker容器云,我们主要分为四个步骤:
第一步 是可以把我们传统的应用容器化,如果是单体架构的应用,可以考虑拆成微服务的模式,然后让业务应用整个以容器为单元去运行。
把应用容器化以及拆分成微服务架构可以带来非常多的好处:
- 支持多种技术栈的应用,比如可以选择最合适的技术去开发业务:
- 提高资源的利用率,以及支持自动的弹性伸缩扩展,比如说快速容灾容错等等。
第二步是加速开发构建部署的过程,也就是我们所说的CI/CD,持续集成跟持续交付。DevOps全流程交付的意思是说,我们可以从业务应用开发,比如说通过Gitlab提交一段代码能够自动的触发整个代码库的自动构建,它会push到统一的企业镜像仓库,我们根据之前定义的部署规则,它可以自动部署到测试,或者是生产环境。
Devops全流程交付能够让我们从开发、构建、集成、部署、运行等整个应用的生命周期变成自动化的方式。
第三步和第四步我们可以应用一些更高级的服务,比如应用编排、负载均衡,弹性伸缩,还有大数据,中间件等等。
最后和大家分享一个时速云的实际落地案例,某制造行业客户如何借力容器技术打造新一代PaaS云平台。
该企业客户的IT业务十分复杂,它的IT业务主要是由第三方外包服务商提供,整个IT部门主要是做系统业务应用的运维管理,所以不同的外包商提供的服务,给IT部门的运维管理造成了非常大的困难。
针对这一客户对运维管理和项目交付的需求,我们在网络隔离,防火墙模式下去部署系统,然后时速云提供了多种网络的部署模型,并且以分层架构的模式去部署容器集群管理系统。
下面这张图是针对客户的三层网络架构专门做的一个部署,时速云容器云平台的一个网络模型图。
我们通过这种基于Docker的PaaS云平台,给客户提供了一个包含DevOps、开发运维、微服务架构、CI&CD、运维管理等在内的针对性的解决方案,从而让客户能够轻松的管理大量的外包服务开发商,并且让业务实现快速交付。