Docker 与 Kubernetes(k8s) 在企业基础设施服务的应用

简介: 大家好,本次内容我在我司上个月的PWorld大会上分享过,线下会议参与人数有限,这次应邀在微信上向更广泛的人群分享,同时也加入了我近期的一些新想法,不仅仅是上次分享的重复。 一、新时代——即基于容器的云时代的来临。

大家好,本次内容我在我司上个月的PWorld大会上分享过,线下会议参与人数有限,这次 应邀在微信上向更广泛的人群分享,同时也加入了我近期的一些新想法,不仅仅是上次分享的重复。

20161022212814

一、新时代——即基于容器的云时代的来临。

20161022212821

下面出场的是容器时代的两大主角——Docker和Kubernetes,未来相当长的时间里,容器时代的种种爱恨情仇,都将在这两大主角之间展开。

20161022212829

先看下Docker:

20161022212840

Docker刚刚三岁半,虽出身草莽,但早已显露王者风范,据说Docker开源之后,很多VMware的老员工就开始找工作了~

再来看下Kubernetes:

20161022212849

Kubernetes不到两岁半,系出名门,脱胎于Google Borg,出道以来吊打各路高手,俨然一位不可一世的富二代!

面世不过两三年的开源项目,就取得了如此广泛的关注度和实际应用,回顾历史,这样的项目屈指可数,那么这种状况的原因又是什么呢?或者说,他们带来了哪些独特的价值呢?

在很多技术资料里,在提到容器的价值的时候,都会出现如下两张图:左边是拿容器和虚拟机的层次结构做对比,说容器是个分层更少、更加轻量的虚拟化工具;右边是拿容器和虚拟机的性能做对比,说容器是个性能更好的虚拟化工具。

20161022212858

那么容器的价值就仅仅是轻量和高性能吗?这显然很不充分,因为容器相对虚拟机的性能提升,最多也就是百分之几十的样子,在IT界,不带来十倍以上的性能提升,是很难被赋予颠覆者地位的。仅仅百分之几十的提升,会迅速被摩尔定律抹平,长期看不值一提。

那么容器的最大价值到底是什么?为了说明这个问题,我们来回顾下基础设施层多年以来的苦苦挣扎~

二、提升抽象层级是基础设施的宿命

20161022212905

不知道各位有没有了解过OASIS指定的TOSCA规范,一个面向云应用拓扑和编排的规范,这个规范的工作已经开始了五年多,我本人也是委员,之前的规范工作主要围绕虚拟机展开,看下这页PPT的左图,TOSCA通过Node Type描述节点(这里可以简单的认为就是一个虚拟机镜像)的属性和对外接口,通过Relationship Type描述描述节点之间的关系,通过Plan描述部署流程等等……这些共同组成了一个Service Template。

20161022212912

我在这里提这个五年前出现的规范的目的是:在这一波容器浪潮出现之前,业界就已经在如何利用虚拟机更好的管理应用的问题上探索多年了。

就好像一个运维人员,不会满足仅仅维护一下服务器,会希望往上层走,创造更大的价值一样~

之前业界也出现过一些基于类似理念的商业产品。

比如Oracle的Virtual Assembly Builder:

20161022212920

比如VMware的vRealize Automation:

20161022212929

这些产品都能利用虚拟机很方便的编排出一些典型的应用拓扑。

可是却很少有人用,我想群里的大部分朋友可能都没用过。

原因是什么呢?

20161022212936

这张图我在之前的PPT里也出现过,又放在这里的意思是:

中间2013年的这种多层架构,相对比较简单,使用脚本部署就已经比较高效了,很少有企业会因为这个事情去采购昂贵的商业软件,而且这些商业软件也没有为部署之外的运维流程带来太多的便捷性。

右边2016年的这种分布式架构,是现阶段的趋势,这种架构给部署和运维都带来了极大的困难,这些昂贵的商业软件也无从处理。

我想这就是原因和尴尬之处吧!

20161022212943

所以说,天堂向左,虚机向右,通过虚拟机来解决分布式系统的部署和运维问题,已经被业界的多年努力验证为此路不通,而这些挤压已久的需求,在容器上找到了突破口。

这就是容器最核心的价值。

三、Docker和Kubernetes实现基础设施的多年梦想

20161022212951

我们来看一下Docker和Kubernetes如何实现基础设施的多年梦想。

20161022212957

Docker,真正的实现了Infrastructure as Code,Infrastructure as Code作为一个Buzz Word已被炒作了多年,以前只是Infrastructure提供一些API,供上层调用,可是仅仅提供了API,还不能说是Code,Code是可以Compile、可以Link的,而Docker实现了这些。

20161022213004

把Docker编译好、链接好的镜像发布到Kubernetes的集群里,Kubernetes就接管了应用的大部分运维工作,kubernetes会负责处理应用的高可用和自动伸缩,对应用的任何一次变更,小到修改一个参数,大到一次全面的升级,都会被Kubernetes纳入版本控制,就像管理代码一样~

可以看到,Docker和Kubernetes联手解决了分布式系统运维的大量问题,但是这远远不是问题的全部。

如果基于Docker和Kubernetes打造一个DevOps平台,还面临着很多问题:

20161022213011

四、我们的进一步工作

20161022213019

现有的开发、集成、测试、运维工具大多为单体应用设计,难以处理微服务带来的复杂度。

所以我们针对这个问题升级了我们原有的产品。

20161022213025

我们使用元数据治理产品对微服务进行全生命周期的管理,使整个研发和交付流程更加顺畅。

20161022213033

我们开发了全新的工作空间,降低了团队间的协作成本。

20161022213039

我们还做了很多很多,这里不一一列举,总而言之,我们通过精益运营建立了一个数字化企业云平台。

20161022213046

说到这里,各位有没有觉得,基于容器的云平台有一种发展方向,就是成为一个更全面的应用服务器,这里的更全面指支持大规模集群环境、更多类型的应用、并更加完整的覆盖软件的生命周期。

但是我们这几年经常听到这句话:

20161022213052

应用服务器已死。

举例来说,基于JAVA的应用服务器,有资源隔离差(JVM缺乏CPU、内存、IO的资源控制能力)、与应用紧耦合(应用服务器需要为应用做出针对性的配置)、依赖管理能力弱(库版本冲突、只能管理Java世界的依赖)、持续集成/部署困难(应用服务器无法参与持续集成、部署应用服务器本身比部署应用复杂的多)等诸多问题,而这些问题在分布式、碎片化的软件环境下,变得日趋严重,所以传统的应用服务器面临了快速的衰败。

但是这些问题总要有个新平台去解决,只是目前旧王已死,新王未立。

在上一页PPT中我们可以看到,容器镜像就像一个包含了运行环境依赖的WAR包,基于容器的云平台也将提供类似消息引擎、JNDI、安全服务、Workload管理、Job管理等能力,而且这些能力将为更多类型的软件提供服务。

最后我们畅想一下未来:

20161022213100

如果像Gartner所说,未来所有的公司都将是IT公司,那么必然不是每个公司都像现在的大型互联网公司一样,在IT的各个技术领域雇佣大量的专业人员,一些共性的需求必将剥离出来,由专门的公司提供解决方案,历史是螺旋上升的,社会分工将被再次重建。

本文转自中文社区-Docker 与 Kubernetes(k8s) 在企业基础设施服务的应用

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
15天前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
56 2
|
25天前
|
Kubernetes 监控 开发者
掌握容器化:Docker与Kubernetes的最佳实践
【10月更文挑战第26天】本文深入探讨了Docker和Kubernetes的最佳实践,涵盖Dockerfile优化、数据卷管理、网络配置、Pod设计、服务发现与负载均衡、声明式更新等内容。同时介绍了容器化现有应用、自动化部署、监控与日志等开发技巧,以及Docker Compose和Helm等实用工具。旨在帮助开发者提高开发效率和系统稳定性,构建现代、高效、可扩展的应用。
|
18天前
|
运维 Kubernetes Docker
利用Docker和Kubernetes构建微服务架构
利用Docker和Kubernetes构建微服务架构
|
3天前
|
Kubernetes 监控 云计算
Docker与Kubernetes的协同工作
Docker与Kubernetes的协同工作
|
15天前
|
存储 Kubernetes 网络协议
k8s的无头服务
Headless Service 是一种特殊的 Kubernetes 服务,其 `spec:clusterIP` 设置为 `None`,不会分配 ClusterIP,通过 DNS 解析提供服务发现。与普通服务不同,Headless Service 不提供负载均衡功能,每个 Pod 都有唯一的 DNS 记录,直接映射到其 IP 地址,适用于有状态应用的场景,如与 StatefulSet 一起部署数据库。示例中通过创建 Nginx 的 StatefulSet 和 Headless Service,展示了如何直接访问单个 Pod 并进行内容修改。
29 3
|
26天前
|
Kubernetes 负载均衡 Cloud Native
云原生应用:Kubernetes在容器编排中的实践与挑战
【10月更文挑战第27天】Kubernetes(简称K8s)是云原生应用的核心容器编排平台,提供自动化、扩展和管理容器化应用的能力。本文介绍Kubernetes的基本概念、安装配置、核心组件(如Pod和Deployment)、服务发现与负载均衡、网络配置及安全性挑战,帮助读者理解和实践Kubernetes在容器编排中的应用。
72 4
|
27天前
|
Kubernetes 监控 Cloud Native
云原生应用:Kubernetes在容器编排中的实践与挑战
【10月更文挑战第26天】随着云计算技术的发展,容器化成为现代应用部署的核心趋势。Kubernetes(K8s)作为容器编排领域的佼佼者,以其强大的可扩展性和自动化能力,为开发者提供了高效管理和部署容器化应用的平台。本文将详细介绍Kubernetes的基本概念、核心组件、实践过程及面临的挑战,帮助读者更好地理解和应用这一技术。
60 3
|
1月前
|
Kubernetes 负载均衡 Docker
构建高效微服务架构:Docker与Kubernetes的完美搭档
【10月更文挑战第22天】随着云计算和容器技术的快速发展,微服务架构逐渐成为现代企业级应用的首选架构。微服务架构将一个大型应用程序拆分为多个小型、独立的服务,每个服务负责完成一个特定的功能。这种架构具有灵活性、可扩展性和易于维护的特点。在构建微服务架构时,Docker和Kubernetes是两个不可或缺的工具,它们可以完美搭档,为微服务架构提供高效的支持。本文将从三个方面探讨Docker和Kubernetes在构建高效微服务架构中的应用:一是Docker和Kubernetes的基本概念;二是它们在微服务架构中的作用;三是通过实例讲解如何使用Docker和Kubernetes构建微服务架构。
61 6
|
1月前
|
Kubernetes Cloud Native 开发者
云原生技术入门:Kubernetes和Docker的协作之旅
【10月更文挑战第22天】在数字化转型的浪潮中,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,引领读者步入云原生的世界,着重介绍Kubernetes和Docker如何携手打造弹性、可扩展的云环境。我们将从基础概念入手,逐步深入到它们在实际场景中的应用,以及如何简化部署和管理过程。文章不仅为初学者提供入门指南,还为有一定基础的开发者提供实践参考,共同探索云原生技术的无限可能。
44 3
|
2月前
|
Kubernetes 持续交付 Docker
利用 Docker 和 Kubernetes 实现微服务部署
【10月更文挑战第2天】利用 Docker 和 Kubernetes 实现微服务部署