写点什么

Kubernetes 创始人 Brendan Burns 访谈录:容器与分布式系统模式

  • 2018-02-25
  • 本文字数:2644 字

    阅读完需:约 9 分钟

看新闻很累?看技术新闻更累?试试下载 InfoQ 手机客户端,每天上下班路上听新闻,有趣还有料!

分布式系统编程并不适合胆小的人,尽管从 CORBA、RMI、Java EE、Web 服务、面向服务的架构 (SOA) 等等平台和工具发展演化,但它更多的是种艺术问题而不是科学问题。

Brendan Burns 在 2015 年撰写的博文中介绍了许多支持分布式系统编程的模式。同为 Kubernetes 的最初贡献者,他和 David Oppenheimer 不久之后在 Usenix 发表了一篇基于设计模式和容器的论文

InfoQ 对话 Burns,他在最近撰写了一本题为《为可扩展的微服务设计分布式系统、模式和范式》的电子书。他和我们介绍了分布式系统模式、容器以及如何对其进行实现。

InfoQ:让我们直奔主题吧。分布式系统已经存在了几十年了。这本书有什么创新内容呢?如果我是公司的程序员或是架构师,除了价格因素之外(这本书是免费的),还有什么吸引我阅读的理由呢?

Brendan Burns:通常之下,将近几年的模式编撰为书需要一段时间,并且大多是一些可以让模式更容易抽象讨论的变革性技术才会编撰成书。像《四人帮(设计模式)》这样的书籍也是在面向对象编程发展将近十年之后才面世,很显然这本书(以及所有 90 年代的模式书籍)都受到了面向对象编程的启发。

对我来说,容器和容器的编排是激发我撰写这本书的动力。我认为“最终我们将使用相同的语言和词汇来讨论这些模式”,这就是我写这本书的原因。当然,每时每刻都有人加入到云和分布式系统的学习中,因此这也是我写书的一部分动机。人们需要通过书本来学习,而不是通过一次次搭建坏的系统来学习成长。

InfoQ:在 Kubecon 2017 大会上的主题演说中,你介绍了如何让分布式系统编程像通过 CS101 课程(计算机科学导论课程)一样容易。有两个问题。正如 Kubecon 所展现的一样,你有曾想过 Kubernetes 会得到这么广泛的采用吗?第二个问题,容器和 Kubernetes 在分布式系统编程中起到什么作用呢?

Burns:承蒙大家厚爱,Joe、Craig 和我作为创始人真的很高兴 Kubernetes 能受到这样的欢迎并广泛使用。我们一直希望它可以真正帮助人们采用云原生设计模式和实践,但看到它能这样发展我们真的很惊讶。真的很感谢将自己的业务和应用押宝在 Kubernetes 上的所有人,为了让他们满意需要更加努力,我认为对整个 Kubernetes 社区和生态系统来说,质量是最好的承诺。Kubernetes 社区确实是一个分布于全世界的社区,不管我们身处何地,有这样的一个软件让我们聚集在一起,这真的很棒。

我认为 Kubernetes 的目标始终是成为分布式系统的自治系统。我喜欢以手动飞机和无人机做比喻。无人机更容易飞行,因为它有机载控制器保持平衡,你只需要告诉它往哪里飞。Kubernetes 是相同的原理,你告诉它需求,它负责保证正确数目,响应应用程序崩溃或是机器故障,它就像你的分布式应用程序的防抱死制动。在回路中的计算机自动响应,保证安全。另外,我认为有了服务负载均衡等东西的存在,你很容易陷入所谓的“基坑成功(Pit
of Success)”,并以一种解耦可扩展的方式实现你的应用程序。

InfoQ:在 Kubecon 2017 大会上的主题演说中,你谈到了使用 MetaParticle 云原生运行环境大众化分布式系统开发。究竟是什么意思呢?Istio 是有代表性的例子吗?

Burns Metaparticle 确实可以帮助我们重新思考如何设计搭建系统。现在我们给每台机器写代码,之后我们用这些 YAML 文件来描述这些独立的程序如何结合在一起。在这个过程中,我们需要学习并使用不同的应用程序、文件格式和语言来描述我们的应用程序。这对新的开发人员来说太复杂太困难了。Metaparticle 是一种新的尝试:“我们是否可以用一个编程语言完成这一系列工作?”。通过这个实验,让缺乏经验的开发人员可以将他们自身的技能转换为云原生设计模式。我认为 Istio 是不同的,Istio 旨在让现有的系统更方便观察,更加动态。对于已经知道如何搭建云原生设计系统的人来说是个很好的工具,但是希望它可以更简单地来监控和使用。

InfoQ:正如你在谈话中所建议的,如果语言需要提供云原生服务,让开发变得更加容易,可能需要好几年才能形成一套标准化的形式。你认为这只是时间长短的事情吗?同时,生态系统是否会提供工具和平台来解决分布式系统开发遇到的一些挑战?

Burns:我认为确实存在两类不同的解决方案。有些事情确实可以解决问题,消除痛苦。类似 Helm Draft 和我们正在做的 VS Code 整合这样的工具可以很好解决问题。我认为这些工具将稳定发展,帮助云原生设计开发人员更加方便地使用 Kubernetes。

我认为还有一类不同的事情是变革性的,可以帮助很多新的开发人员开始使用云原生服务。就像好的 IDE 对于 C++ 开发人员来说一样,虽然 IDE 不能帮你成为一名优秀的 C++ 程序员,但它可以给优秀的 C++ 程序员带来更好的体验。还有像 Java 或是 C#这样优秀的语言可以驱动一些新的开发人员。我认为这两方面都是不可或缺的。

InfoQ:大多数参与过分布式系统编程的人都曾受困于分布式计算的八大误区。你书中介绍的分布式设计模式是否可以帮助解决这些问题,如果可以的话,是通过什么方法解决的呢?

Burns:我认为它可以帮助你应用那些可以创建更健壮系统的模式,而且书中介绍了你在搭建系统的时候应该考虑的设计事宜。我希望,它可以提供一种共同语言,便于人们一起讨论系统,这样人们就不需要一次又一次学习相同的内容,相反我们都在相互学习相同的模式。这并不是魔法,人们还是需要切身学习很多经验。

InfoQ:Kubecon 会议中的许多谈话可能都会让开发工作变得更加无聊(只是在讨论如何工作)。你认为现在的社区发展到了什么阶段?大胆猜测,五年后和现在会有什么不同?

Burns:我非常希望可以像讨论 Posix 或 x86 指令集一样讨论 Kubernetes。这确实是很有价值的东西,人们可以学习它来完成自己的工作,但这还不是真正的点。我希望今后可以像讨论垃圾收集或是面向对象编程一样讨论 Kubernetes。它是可以帮助你完成工作的重要工具,但它不是很新的东西,不是拥有很多狂热粉丝的产品。

我希望我们回头看的时候可以说:“哇,在这个伟大的抽象层上我们做出了多少成果”,因为 Kubernetes 并不是尽头,它是一个很好的基础,我们可以在此之上搭建很多东西。

书中提到的代码示例可以在 Github 库下载。

查看英文原文 Q&A with Kubernetes Founder Brendan Burns on Containers and Distributed System Patterns


感谢罗远航对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2018-02-25 18:002229
用户头像

发布了 218 篇内容, 共 68.6 次阅读, 收获喜欢 76 次。

关注

评论

发布
暂无评论
发现更多内容

架构师训练营第 1 期第 13 周学习总结

好吃不贵

极客大学架构师训练营

工业区块链正在改变什么?

CECBC

环保

完美!凭借这份阿里大佬分享的4170页Java高手真经笔记!offer拿到手软

Java~~~

Java 程序员 编程语言 电子书 架构资料

架构之书:我们从何处来?我们是谁?我们向何处去?

lidaobing

架构 编程的未来

程序员什么时候就该辞职了?

Java架构师迁哥

网易区块链打造可信数字身份认证应用新场景,赋能科技峰会

CECBC

数字身份

星环科技自动特征工程论文被ICA3PP2020接收

星环科技

AI 数据集

A Guide for Accidental Project Managers

Geek_ed0696

pmp project manager role of PMP PMP Certification greycampus

QoS简介

全球最火的程序员学习路线!2020年GitHub上那些优秀Android开源库总结,吊打面试官系列!

欢喜学安卓

android 程序员 面试 移动开发

架构师 3 期 3 班 -week4- 总结

zbest

总结 week4

ES6中的Promise和Generator详解

程序那些事

新特性 ES6 Promise 程序那些事 Generator

闭嘴,别再问什么是锁了

程序员老猫

乐观锁 悲观锁 分布式锁 java锁 公平锁

利用Python进行数据分析(原书第2版)免费下载

计算机与AI

Python 数据分析 数据科学

直播报名 | 携程技术沙龙——前端测试技术创新与实践

携程技术中心

AI 数据分析

甲方日常 70

句子

工作 随笔杂谈 日常

【智简联接,万物互联】华为云·云享专家董昕:Serverless和微服务下, IoT的变革蓄势待发

华为云开发者联盟

Serverless 物联网 IoT

架构师训练营第 1 期 week13 总结

张建亮

极客大学架构师训练营

Rancher开源Harvester:基于K8S的超融合基础架构软件

Rancher

Kubernetes rancher

Superset 助力企业级大数据 Ad-hoc 查询

麻婆豆腐没麻婆

数据分析 Apache Superset BI数美

芯片破壁者(二十二):政府与半导体间的“美国往事”

脑极体

游戏服务器多钱一个月呢?

德胜网络-阳

架构师训练营第 1 期 week13

张建亮

极客大学架构师训练营

生产环境全链路压测建设历程12:通过生产压测发现的问题摘录

数列科技杨德华

全链路压测

【变与不变】架构中的边界划定

soolaugust

编程 架构 设计

程序员如何解决中年危机?我的阿里春招之路分享,顺利通过阿里Android岗面试

欢喜学安卓

android 程序员 面试 移动开发

架构师训练营第 1 期第 13 周作业

好吃不贵

极客大学架构师训练营

技术选型背后的国家利益:区块链自主化道路的交锋

CECBC

科技

re:Invent 重磅回顾 | AWS 重塑机器学习的四大亮点,触及每一位 AI 工作者

亚马逊云科技 (Amazon Web Services)

云计算 AWS

TeamLeader不可不知的三种团队建设形式

Alan

团队管理 个人成长 28天写作

云智一体:攀登2021智能经济新山峰

脑极体

Kubernetes创始人Brendan Burns访谈录:容器与分布式系统模式_DevOps & 平台工程_Rags Srinivas_InfoQ精选文章