[翻译] 再见 docker

本贴最后更新于 2241 天前,其中的信息可能已经时移世异

原文链接:https://technodrone.blogspot.com/2019/02/goodbye-docker-and-thanks-for-all-fish.html

早在 20187 月,我开始撰写一篇关于即将死亡的 Docker 作为一家公司(也可能是一项技术)的博客文章,但我还没有完成并发布该帖子,现在是时候实际发布该帖子了。

https://twitter.com/maishsk?ref_src=twsrc%5Etfw%7Ctwcamp%5Etweetembed%7Ctwterm%5E1019115484673970176&ref_url=https%3A%2F%2Ftechnodrone.blogspot.com%2F2019%2F02%2Fgoodbye-docker-and-thanks-for-all-fish.html

所以就是这样

当然 docker 仍然活着,大多数人也在使用 docker。并且将在可预见的未来继续这样做(可预见的未来有多远 - 尚待确定)。我之所以选择这个博客标题是因为,我认为 Docker 作为一家公司的日子已经屈指可数,也许也是一项技术。如果我会用几分钟的时间放飞自我 - 我将与你分享我的思想。

多年前 - Docker 是改变世界的公司 - 我们可以肯定地说 - 现在仍在改变世界。容器和容器背后的技术已经存在很多年了,早在 docker 这个词被人们想到之前,甚至变成了动词(“Dockerize all the things”),但是 Docker 是让大众消费这种技术的公司容器,简单易行。大多数技术公司(或者至少是那些认为自己是现代科技公司的公司)将使用 Docker 或容器作为其产品或管道的一部分 - 因为它非常有意义,并为整个过程带来了如此多的好处。

在过去的 12-24 个月里,人们逐渐意识到 docker 工作已经走上了正轨,而且技术无法为他们今天所拥有的东西提供额外的价值 - 并决定开始寻找其他地方额外的优势。

Kubernetes 赢得了容器编排的战争,我认为任何人都不能否认这一事实。Docker 本身采用了 Kubernetes。总会有专门的玩家为 Docker Swarm,Mesos,Marathon,Nomad 提供特定用例 - 但事实上的标准是 Kubernetes。所有 3 大云提供商现在都拥有一个管理的 Kubernetes 解决方案,他们为客户提供解决方案(因此最终会落幕他们自己多年来建立的自制解决方案 - 因为只有一个解决方案。每个人都在构建更多服务并提供更多解决方案,以吸引更多客户,增加收入。

故事已经完成,这没什么。接下来

有点闪亮的事情......目前,Kubernetes 使用 docker 作为底层容器引擎。我认为 Kubernetes 社区了解 Docker 作为容器运行时(我特意使用这个术语)是尽快将产品推出门的最终解决方案。他们(明智地)很早就明白他们需要选择切换容器运行时 - 并允许 Kubernetes 的消费者做出选择。

该 OCI(Open__Container__Initiative)(http://www.opencontainers.org/)-与它带来的Runtime 规范- 它打开了大门,允许我们所有人使用除了 docker 之外的其他东西作为运行时。他们正在稳步增长。Docker 不再是唯一正在使用的运行时。他们是社区的成长 - 慢慢地分享除了 Docker 之外如何使用其他东西的知识。Kelsey Hightower -多年来从 CRI-O%20v1.0.0-beta.0)到容器再到 gvisor一直在努力更新他的 Kubernetes(很棒的工作 - 老实说),所有潮流的人都不再只使用 docker 作为底层运行时。今天有许多其他选择明确的容器katacontainers 和名单不断增长。

大多数人(包括我自己)没有足够的知识和专业知识,如何将 runtime 换成他们想要的东西,通常只是默认开箱即用。当人们明白他们可以轻松地做出更换容器运行时的选择,并且知识就在那里并且容易随时可用时,我认为我们没有任何理由让我们再使用 docker,因此 Docker 作为一种技术而作为一家公司将慢慢消失。与 Docker 提供的相比,即将推出的其他容器运行时将更快,更安全,更智能,功能更丰富(其中一些已经存在)。如果您拥有更好,更智能,更安全的产品 - 为什么人们会继续使用不再适合其不断增长的需求的技术?

对于 Docker - 为了避免这种结果 - 我建议尽可能多地投入精力 - 为任何工作负载创建最佳的运行时 - 这样 docker 仍然是每个人都使用的事实上的标准。这个陈述的问题是容器运行时没有钱。Docker 从未在运行时赚钱,他们在上面的企业功能和容器运行时上寻找收入。他们将如何解决这个问题 - 超出了我和本文的范围。

docker 社区一直在稳步下降,事件的受欢迎程度一直在下降,新功能和公告的数量正在下降,并且在过去一两年中一直在下降。

有人告诉我一段时间 - 对事情说不好或给坏消息通常很容易。我们可以很容易地说这是错误的,这没有用,这应该改变。但是,如果没有对某些事情做出积极的改变 - 你就会成为“厄运和沮丧”,“死神”。不要成为那样的人。

我想听听他们的建议,并加上一些关于 - 这对你今天意味着什么。你应该开始投资了解这些其他运行时如何能够帮助你,适合他们的地方,增加你的知识和专业知识 - 这样你就可以为此做好准备而不会在其他人停止使用 docker 时感到惊讶,你发现自己不得不急于适应所有基础设施。我认为这是不可避免的。

这是我想在 8 个月前写的帖子......

触动我今天完成这篇文章的原因是来自 Scott Mccarty 的一篇文章- 关于即将推出的 RHEL 8 beta -Enterprise Linux 8 Beta:一套新的容器工具- 以及我发布的推文

  • 翻译
    58 引用 • 84 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 88250

    只有用的人多的东西才会成为主流,OCI 可以看作是把 docker 实现中容易抽象统一的部分制定成规范接口,docker 作为标准参考实现。但话说回来,规范(Spec)在很多时候只是一种产品包装的噱头。比如 “XXX 厂商的产品实现了 XXX 规范”,实际上某些关键部分还是只能直接用底层实现。

    类似活生生的案例可以参考 Java 领域,Spring、Hibernate 这类实现引领着 JSR 规范,但实际开发中很少有开发者去用规范定义的接口,都是直接用实现,因为实现好用啊。 中间件厂商可以标榜他们实现了各种规范,而推动规范的也正是它们自己,联盟的城墙又高又厚了一些,完美。

    功能类似的同类竞品只要稍微有点思考能力,肯定是不会去实现所谓的规范,他们会另辟蹊径,从技术上打败已有规范,占领自己的山头,再次竖起另一面规范的大旗。

    没错,这是一个悲伤的故事。但和我们基层码农有关系么?

    1 回复
  • yuanhenglizhen

    有关系啊,在熟悉目前实现的基础上,学习准备其他优秀的实现,作为备用方案。避免灾难来临时的无从下手。这大概就是作者想说的把

yuanhenglizhen
笔落兴亡定三端之妙,墨写清白尽六艺之奥

推荐标签 标签

  • 工具

    子曰:“工欲善其事,必先利其器。”

    298 引用 • 763 回帖
  • Word
    13 引用 • 41 回帖
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖 • 1 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    326 引用 • 1395 回帖
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    12 引用 • 59 回帖 • 5 关注
  • RabbitMQ

    RabbitMQ 是一个开源的 AMQP 实现,服务器端用 Erlang 语言编写,支持多种语言客户端,如:Python、Ruby、.NET、Java、C、PHP、ActionScript 等。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。

    49 引用 • 60 回帖 • 347 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 63 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    59 引用 • 25 回帖 • 2 关注
  • PostgreSQL

    PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

    22 引用 • 22 回帖
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 3 关注
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    56 引用 • 85 回帖 • 1 关注
  • 印象笔记
    3 引用 • 16 回帖 • 1 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    291 引用 • 4495 回帖 • 656 关注
  • C

    C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

    86 引用 • 165 回帖 • 4 关注
  • Electron

    Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。

    15 引用 • 136 回帖 • 6 关注
  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 34 关注
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    240 引用 • 224 回帖 • 1 关注
  • FlowUs

    FlowUs.息流 个人及团队的新一代生产力工具。

    让复杂的信息管理更轻松、自由、充满创意。

    1 引用 • 2 关注
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 565 关注
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    96 引用 • 155 回帖 • 1 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    42 引用 • 130 回帖 • 250 关注
  • danl
    172 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    411 引用 • 3588 回帖 • 1 关注
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    20 引用 • 37 回帖 • 579 关注
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    438 引用 • 1250 回帖 • 594 关注
  • AWS
    11 引用 • 28 回帖 • 3 关注
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    29 引用 • 202 回帖 • 27 关注