写点什么

将微服务浓缩为函数:Adrian Cockcroft 在 microXchg 大会上讨论了无服务器架构

  • 2017-03-01
  • 本文字数:1892 字

    阅读完需:约 6 分钟

在柏林举行的 microXchg 微服务大会上, Adrian Cockcroft 做了题为“将微服务浓缩为函数”的演讲。演讲的关键要点包括:网络速度的提升、二进制协议的使用、配置管理和容器技术等使得部署包含多种微服务的应用程序成为可能;由无服务器架构技术带来的机会为在数据中心运行快速开发的函数即服务(functions-as-a-service,FaaS)带来了更多的可能;为了有效地交付业务价值,现代公司必须能够快速地构建原型和应用程序;现代企业里软件开发的最大挑战是与企业内的人和流程紧密相关的。

身为AWS 的云架构战略VP,Cockcroft 在演讲开始首先讨论了十年前的软件交付状态,以及它们与现代工程师们具备的能力之间的关系。在九十年代以及21 世纪初,手工部署物理硬件的挑战带来了运维团队对部署流程的优化,尽量少地涉及人工产品(也就是单体应用程序)。这就导致了所谓的“大泥球”( big ball of mud )架构反模式的产生。

尽管 21 世纪初在软业开发业中面向服务架构( Service Oriented Architecture ,SOA)以及相应的 WS-* 很流行,刚才提到的最小化可部署人工产品的趋势,再加上局域网内每秒 1Gb 的网络传输速度限制,这些催生了由粗粒度 API 提供的大型服务,它们利用一定数量的 SOAP/XML 消息进行通信。相对应的,现代局域网络的传输速度已经可以达到每秒25Gb ,而且对 Avro gRPC 简单二进制编码等许多高效的二进制编码协议的使用,这些改进使得消息通信效率提升了至少两个数量级。

最新一代的 AWS 实例相互之间的连通网速为 25Gb/s,而不是 1Gb/s,这个优势加上使用 Avro 和 gRPC 等二进制通信协议(要是你更聪明的话就直接做简单的二进制编码……),这些都使得最新的微服务架构风格成为可能。

大概是五年前出现了第一代 DevOps 工具,比如 Chef Puppet 等,这些让自动化部署和配置硬件,以及持续部署和升级软件成为可能。Cockcroft 谈到当初他还在 Netflix 工作时,还没有采用这种“自动化系统管理”的方式,所以 Netflix 团队采用的是不可变基础架构。在Netflix 的系统里,像预定制的亚马逊服务器镜像( Amazon Machine Images ,AMIs)这样的粗粒度程序,都会通过可编程的模式与一个虚拟机计算实例相关联,并且部署在负载均衡器后面的可动态扩展的自动扩展组( Auto Scale Group ,ASG)里。这样就可以支持对应用程序功能的“当场替换”,而不是通过操作系统命令来控制部署和升级。

更近一些,以容器一类的技术为代表的第二代DevOps 工具更进一步地推动了对不可变架构的应用,这种操作系统级的虚拟化技术让大家可以更快地创建和实例化软件系统的各个部分,让部署时间从几分钟降为几秒钟。对容器技术的广泛使用和 Docker 形成的事实标准也创造了标准化资源。比如说,许多数据库和中间件供应商都可以提供官方版的 Docker 镜像,其中提前打包了他们的产品,并且做了一般性的配置。

Cockcrost 表示,最新的“无服务器架构”或者“函数即服务”技术风潮已经开启了软件开发业的一次新革命。之前使用虚拟机和容器进行“快速部署和持久运行”的模式已经过时了,现在是要使用无服务器架构技术进行“快速部署和按需(按付费)运行”。

有了 AWS Lambda 之类的 FaaS 或无服务器架构等技术带来的简化编程模型、弹性部署、可组合性等好处,Cockcroft 表示整个系统都可以快速建立原型和构建。而像 AWS Greengrass 一类的技术,则可以让 AWS Lambda 函数离线地运行在基于 Linux 的物联网设备上,因此可以进一步扩展无服务器架构技术的适用范围和可用性,“从数据中心到最前端,也可以是混合型”。

随着 AWS Lambda 一类无服务器架构技术的兴起,整个系统都可以只需几天便构建完毕,你该问问你自己:“我该把团队投入到升级迁移类活动中,还是干脆把现在的应用程序重写一套呢?”

在演讲的最后,Cockcroft 表示在许多现代企业中,软件开发的问题总是与企业中的人和流程密切相关的。反向康威操纵( Inverse Conway Maneuver )之类的方法,以及 Pheonix 项目 DevOps 手册等资源都可以用于驱动变革性的改变。微服务架构风格就是一个建立跨功能、自治的和紧密配合的业务单元的成功案例。

微服务不适用于组织仓库。在微服务开发中,要在单个服务的边界内有对开发活动的高度信任。服务供应商之间的任何低信任度行为都要通过良好设计的 API 以及服务水平协议(service level agreements,SLA)来解决。

Adrian Cockcroft 的 microXchg 演讲“将微服务浓缩为函数”视频可以在大会的YouTube 频道找到。关于这个话题的更多内容可以参考Cockcroft 的一篇最新博客:“业务逻辑从单体到微服务,再到函数的演变”。

阅读英文原文 Shrinking Microservices to Functions: Adrian Cockcroft Discusses Serverless at microXchg

2017-03-01 18:003224
用户头像

发布了 152 篇内容, 共 79.9 次阅读, 收获喜欢 64 次。

关注

评论

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

为什么这些SQL语句逻辑相同,性能却差异巨大?

电子尖叫食人鱼

数据库 sql

面试官:如何实现大模型连续对话?

量贩潮汐·WholesaleTide

面试

DiskCatalogMaker for Mac 磁盘管理工具

晨光熹微

在AI时代,挖掘用户真实需求比技术实现更具挑战性

qife122

开源项目 需求分析

低代码演进:从辅助工具到核心引擎,驱动企业关键业务数智化升级

量贩潮汐·WholesaleTide

低代码

告别工具混战!TitanIDE,AI 开发者的全流程研发加速器

行云创新

模型开发训练 Cloud IDE TitanIDE 云端 IDE

踩过坑后,我发现了这几个运维神器

外滩运维专家

网站监控 免费SSL证书 监控电话 短信接口 免费监控

Room Arranger for Mac 简单易用的室内设计软件

晨光熹微

万界星空科技锂电池MES解决方案

万界星空科技

mes 锂电池 新能源电池 制造业转型 锂电池mes

右键菜单增强工具专业版 Mouseboost Pro for mac

晨光熹微

回顾Meltdown与Spectre漏洞披露事件:风险与启示

qife122

漏洞披露 侧信道攻击

2015年漏洞实验室课程公告 - CanSecWest与SyScan技术研讨会

qife122

漏洞利用 内核漏洞 内核漏洞模糊测试

PDF文件压缩软件 Recompress for Mac

晨光熹微

Playwright自动化测试系列课(3) | 第二阶段:核心技能与调试 ​​交互操作大全

测吧(北京)科技有限公司

案例速击!TitanIDE 凭硬核实力斩获多行业标杆合作

行云创新

CloudIDE 云端 IDE

腾讯云AIoT 2.0产品解决方案全面升级,一站式智能终端开发新范式

极客天地

javax.security.auth.login.LoginException: Message stream modified (41)

刘大猫

人工智能 数据挖掘 算法 数据分析 LoginException

高德地图开放平台世界地图服务全新上线

高德开放平台

前端 高德地图 地图服务 海外应用 世界地图服务

【Spring三级缓存解密】如何优雅解决循环依赖难题

不在线第一只蜗牛

spring

Bettertouchtool for Mac 触控板增强软件

晨光熹微

【7.23 直播】手把手教你零基础玩转 IoTDB 时序大模型!

Apache IoTDB

Couchbase 可观测性最佳实践

观测云

couchbase

Golang基础笔记十三之context

Hunter熊

Go 后端 Context 超时控制 传递数据

鸿蒙开发中与 AI 编码助手的共处之道(ArkTS 视角)

谢道韫

Overlay for Mac 图像和文档透明显示工具

晨光熹微

Master of Typing 3 for Mac 打字大师 专业的打字练习软件

晨光熹微

多功能代码编辑器BBEdit for Mac

晨光熹微

开源对话式 AI 平台 Intervo:支持电话、语音、聊天多渠道;Runway 发布新动捕模型,支持唇同步和复杂动作捕捉丨日报

RTE开发者社区

腾讯云GooseFS团队与厦门大学合作成果 AC-Cache入选 PPOPP

极客天地

My Metronome for Mac 音乐节拍器软件

晨光熹微

Trickster for Mac 快速访问文件工具

晨光熹微

将微服务浓缩为函数:Adrian Cockcroft在microXchg大会上讨论了无服务器架构_亚马逊云科技_Daniel Bryant_InfoQ精选文章