产品战略专家梁宁确认出席AICon北京站,分享AI时代下的商业逻辑与产品需求 了解详情
写点什么

将微服务浓缩为函数: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:002741
用户头像

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

关注

评论

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

生产制造关键业务模型拆解与平台化演进

华为云开发者联盟

后端 物联网 华为云 华为云开发者联盟 企业号 8 月 PK 榜

Node与Express后端架构:高性能的Web应用服务

互联网工科生

Web Node Express

共创共赢,天翼云携手用友打造商业创新一体化解决方案!

天翼云开发者社区

云计算 AI 数据治理

鹏云块存储在多副本情况下,如何兼顾数据一致性和效率?

鹏云网络

分布式系统 数据强一致性 副本一致性 分布式存储,

科兴未来 | 2023年SCIP绿色化学化工创新创业大赛!

科兴未来News

合约一键跟单软件开发,币安欧意交易所合约跟单API量化机器人搭建

V\TG【ch3nguang】

量化交易机器人开发 合约跟单 币安智能链

GaussDB技术解读系列:高安全之密态等值

华为云开发者联盟

数据库 后端 华为云 华为云开发者联盟 企业号 8 月 PK 榜

泰山众筹拼团互助模式系统DAPP定制开发

V\TG【ch3nguang】

众筹 拼团

IPQ6010 with QCN9074 Solution|5G and Wi-Fi 6: A Dynamic Duo for the Connected Future

wallyslilly

IPQ6010 QCN9074

MatrixOne内核1.0.0-RC1版本正式发布啦!

MatrixOrigin

数据库 云原生 MatrixOrigin MatrixOne 矩阵起源

Alfred 5 for Mac(Mac应用快速启动器) v5.1.2(2145)中文激活版

mac

Alfred 苹果mac Windows软件 快速启动工具

突破连接壁垒,火山引擎边缘云网络的先行之路

火山引擎边缘云

云服务边缘架构 边缘云 边缘云原生

HarmonyOS Codelab 优秀样例——购物应用,体验一次开发多端部署魅力

HarmonyOS开发者

HarmonyOS

互助公排模式系统功能及矩阵开发设计

V\TG【ch3nguang】

互助 公排模式

软件测试/测试开发丨Web自动化测试策略

测试人

Python 程序员 软件测试 自动化测试 测试开发

移动应用高级语言开发——并发探索

OpenHarmony开发者

OpenHarmony

小灯塔系列-中小企业数字化转型系列研究——企业邮箱测评报告

向量智库

怎样快速选择正确的可视化图表?

树上有只程序猿

数据可视化

软件测试/测试开发丨Selenium Web自动化测试基本操作

测试人

Python 软件测试 自动化测试 测试开发 selenium

斩获“年度突破成果”奖!天翼云构建强大AI算力基础,制胜人工智能新时代

天翼云开发者社区

云计算 云服务 云平台

NFTScan 正式上线 Base NFTScan 浏览器和 NFT API 数据服务

NFT Research

NFT\

2023-08-28:用go语言编写。给你一个正整数数组nums, 同时给你一个长度为 m 的整数数组 queries。 第 i 个查询中,你需要将 nums 中所有元素变成 queries[i] 。

福大大架构师每日一题

福大大架构师每日一题

区块链上增发代币发行合约系统搭建开发

V\TG【ch3nguang】

智能合约 代币

低代码助力加速构建应用程序

高端章鱼哥

低代码开发 应用程序 JNPF

阿里云 MSE 助力开迈斯实现业务高增长背后带来的服务挑战

阿里巴巴云原生

阿里云 微服务 云原生

互助系统源码|USDT众筹理财系统模型搭建开发

V\TG【ch3nguang】

USDT承兑支付系统开发 理财系统

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