Twitter上 Docker和社区就容器格式标准化争论不休

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 本文讲的是Twitter上 Docker和社区就容器格式标准化争论不休【编者的话】Docker的容器镜像是否应该完全标准化?Docker是否应该在公开定义的标准化革新上退缩?这是最近Twitter上, Google公司的首席布道师Kelsey Hightower和Docker创始人 Solomon Hykes之间激烈争论的话题。
本文讲的是Twitter上 Docker和社区就容器格式标准化争论不休【编者的话】Docker的容器镜像是否应该完全标准化?Docker是否应该在公开定义的标准化革新上退缩?这是最近Twitter上, Google公司的首席布道师Kelsey Hightower和Docker创始人 Solomon Hykes之间激烈争论的话题。

Hightower 希望Docker的镜像格式是完全标准化的,这样 各个公司包括Docker自己,可以在标准定义之上构建附加的功能。而Hykes在全标准化上非常犹豫,他认为标准化格式太新颖革新太超前。

争论的焦点集中在Docker应当贡献多少容器技术给(OCI),创建一个厂商中立的容器镜像及运行定义。镜像可以是包或者容器本身,附带上应用。运行引擎用来运行容器,提供下层OS的功能支持。

最近Apache Mesos 版本1的发布也拉开了争论的序幕,当时Hightower在产品发布后评论道:哪个厂家愿意第一个发布用于运行Docker容器的第三方软件(他后续发表说Joyent就是第一个)。

他在Twitter上争论的是:理论上运行容器镜像应该不受限于任何运行环境。他写到:“Docker镜像格式在容器业中已成为一个伟大的统一,若Docker能在任何环境下运行,将发挥其最大的潜能“。

Hykes 插话道,在一系列推文中第三方公司声明支持的Docker容器格式都仅仅支持全量功能的一部分,用户若使用这些第三方软件,则会错失一些功能。
1.png

Hykes 反驳道OCI的容器格式是个“伪标准”,最多也只能算作一个中间格式。对于Hightower而言,这些话是最令他惊讶不已的坦言。Hykes认为:Docker已经完成了支持OCI的工作,并已经发布,而Docker版本的迭代速度如此之快,以至于标准化的革新将减缓。
2.png

3.png

4.png

这样的回应令Hightower非常失望,他在Twitter上发布评论:“我本来非常坚信Docker可以将容器技术普及化,但是令人担忧的是一个人想要控制整个趋势。”

问题是第三方厂商构建在Docker上的工作是基于不完整规范的。

“对于大部分Docker的应用者,并不需要所有的特性,如服务发现,集群管理等很多特性均不必须。这时的Docker 就像是公共特性。”Hightower 在Cloudcast的播客采访中回答道:“ 所有有趣的事都构建在上面”。

尽管Hightower 声明并不站在他雇主的立场上发表言论。然而他本身就是Google一系列开源技术的布道师,包括 Go 语言和 Kubernetes(一个支持Docker格式的容器编排工具)。Google发布Kubernetes 是为了鼓励容器的大规模应用,归因于Google想推广Google自有基于Kubernetes和基于容器的云平台。

Cloudcast 的老板Brian Gracely 警示大家,要参考过去的教训:若Docker过于控制镜像格式,会同当年VMWare过于控制虚拟机格式的后果一样,限制第三方仅支持辅助功能,在OVF已经完成的那些VM格式标准化工作,到目前为止都未得到广泛的应用。

Hightower 在播客中说:“这件让大家都打包APP入Docker的事,之所以没有其他的平台愿意构建镜像定义或者容器运行环境的原因是,我们信任Docker和OCI可以做到,若我们可以号召90%的人来参与,那么就可以所有人来讨论对那10%要做些什么,以及那10%是什么。”

这些不确定性因素不利于容器格式的标准化,企业应用也会随之停滞。

当然这也并不是个新话题,去年CoreOS CEO Alex Polvi曾公开表达,OCI的镜像的定义过于狭隘。红帽的首席软件工程师今年在TNS 播客OSCON 上也发表过类似的评论。而Docker并未立刻就评论做出回应。

原文链接:Container Format Dispute on Twitter Shows Disparities Between Docker and the Community(翻译:Chilly)

原文发布时间为:2016-11-06

本文作者:Chilly

本文来自云栖社区合作伙伴Dockerone.io,了解相关信息可以关注Dockerone.io。

原文标题:Twitter上 Docker和社区就容器格式标准化争论不休

相关文章
|
11天前
|
Ubuntu Linux pouch
Docker容器管理工具
文章介绍了Docker容器管理工具,以及早期使用的LXC容器管理工具,包括它们的安装、使用和相关技术特点。
40 10
Docker容器管理工具
|
11天前
|
监控 数据管理 pouch
Docker容器技术概览
关于Docker容器技术的概览,包括Docker的优势、劣势、核心技术、容器所依赖的技术,以及Docker容器的管理和编排工具。
41 7
Docker容器技术概览
|
11天前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
11天前
|
NoSQL 应用服务中间件 Redis
Docker跨宿主机容器通信-通过网络跨宿主机互联
这篇文章介绍了Docker容器跨宿主机通信的实现方法,包括Docker的四种网络模式(host、none、container、bridge)以及如何通过修改网络配置和添加路由规则来实现不同宿主机上的容器之间的互联。
33 0
Docker跨宿主机容器通信-通过网络跨宿主机互联
|
11天前
|
应用服务中间件 nginx Docker
Docker同一台宿主机容器通信-通过容器名称互联
本文详细介绍了如何通过容器名称实现同一宿主机上容器间的互联,并提供了实战案例。首先,文章解释了容器间通过自定义名称访问的原理,随后演示了创建并连接Tomcat与Nginx容器的具体步骤。此外,还讨论了配置中可能出现的问题及解决方案,包括避免硬编码IP地址和使用自定义容器别名来增强系统的灵活性与可维护性。通过这些实践,展示了如何高效地配置容器间通信,确保服务稳定可靠。
16 1
Docker同一台宿主机容器通信-通过容器名称互联
|
3天前
|
持续交付 开发者 Docker
掌握 Docker:容器化技术在现代开发中的应用
Docker 是一个开源容器化平台,使开发者能够将应用程序及其依赖项封装在轻量级容器中,确保跨平台的一致性。本文介绍了 Docker 的基本概念、核心组件及优势,并展示了其在快速部署、一致性、可移植性和微服务架构中的应用。通过示例说明了 Docker 在本地开发环境搭建、服务依赖管理和 CI/CD 流程中的作用,以及多阶段构建、资源限制和网络模式等高级特性。掌握 Docker 可大幅提升开发效率和应用管理能力。
|
11天前
|
应用服务中间件 Shell nginx
Docker容器操作基础命令
关于Docker容器操作基础命令的教程,涵盖了从启动、查看、删除容器到端口映射和容器信息获取的一系列常用命令及其使用方法。
52 14
|
8天前
|
运维 安全 开发者
Docker容器技术
Docker容器技术
28 6
|
8天前
|
Cloud Native 持续交付 Docker
云原生技术实践:Docker容器化部署教程
【9月更文挑战第4天】本文将引导你了解如何利用Docker这一云原生技术的核心工具,实现应用的容器化部署。文章不仅提供了详细的步骤和代码示例,还深入探讨了云原生技术背后的哲学,帮助你理解为何容器化在现代软件开发中变得如此重要,并指导你如何在实际操作中运用这些知识。
|
8天前
|
负载均衡 大数据 测试技术
docker容器技术有哪些应用场景?
docker容器技术有哪些应用场景?
19 5