[翻译] 再见 docker

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

原文链接: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:一套新的容器工具- 以及我发布的推文

  • 翻译
    57 引用 • 83 回帖 • 1 关注

相关帖子

欢迎来到这里!

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

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

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

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

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

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

    1 回复
  • yuanhenglizhen

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

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

推荐标签 标签

  • 创业

    你比 99% 的人都优秀么?

    82 引用 • 1398 回帖 • 1 关注
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 383 回帖 • 2 关注
  • 资讯

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

    53 引用 • 85 回帖
  • 心情

    心是产生任何想法的源泉,心本体会陷入到对自己本体不能理解的状态中,因为心能产生任何想法,不能分出对错,不能分出自己。

    59 引用 • 369 回帖 • 1 关注
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    476 引用 • 899 回帖
  • 安装

    你若安好,便是晴天。

    128 引用 • 1184 回帖
  • Windows

    Microsoft Windows 是美国微软公司研发的一套操作系统,它问世于 1985 年,起初仅仅是 Microsoft-DOS 模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家户户人们最喜爱的操作系统。

    215 引用 • 462 回帖
  • Sandbox

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

    368 引用 • 1212 回帖 • 577 关注
  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 427 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 458 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 43 关注
  • Spark

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

    74 引用 • 46 回帖 • 550 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    14 引用 • 7 回帖 • 1 关注
  • Sphinx

    Sphinx 是一个基于 SQL 的全文检索引擎,可以结合 MySQL、PostgreSQL 做全文搜索,它可以提供比数据库本身更专业的搜索功能,使得应用程序更容易实现专业化的全文检索。

    1 引用 • 178 关注
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    76 引用 • 390 回帖
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    18 引用 • 72 回帖 • 1 关注
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    90 引用 • 59 回帖 • 3 关注
  • iOS

    iOS 是由苹果公司开发的移动操作系统,最早于 2007 年 1 月 9 日的 Macworld 大会上公布这个系统,最初是设计给 iPhone 使用的,后来陆续套用到 iPod touch、iPad 以及 Apple TV 等产品上。iOS 与苹果的 Mac OS X 操作系统一样,属于类 Unix 的商业操作系统。

    84 引用 • 139 回帖
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 36 关注
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    51 引用 • 37 回帖
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 84 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 18 关注
  • 自由行
    1 关注
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    35 引用 • 35 回帖
  • flomo

    flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。

    3 引用 • 80 回帖 • 1 关注
  • RabbitMQ

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

    49 引用 • 60 回帖 • 393 关注
  • FlowUs

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

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

    1 引用 • 2 关注