阿里、蚂蚁、晟腾、中科加禾精彩分享 AI 基础设施洞见,现购票可享受 9 折优惠 |AICon 了解详情
写点什么

热度 3 年猛增 20 倍,Serverless & 云开发的技术架构全解析

  • 2019-05-30
  • 本文字数:3735 字

    阅读完需:约 12 分钟

热度3年猛增20倍,Serverless & 云开发的技术架构全解析

作为一个不断发展的新兴技术, Serverless 热度的制高点已然到来。或许,Google Trends 所显示的 3 年猛增 20 倍的“ Serverless ” 搜索量,可以佐证 Serverless 在整个行业中的火爆程度。



不仅如此,据 KBV 研究公司新发布的《全球 Serverless 架构市场》及 RightScale 云服务状况报告 2018 版显示,全球 Serverless 架构的市场渗透率已超 75%,市场规模预计到 2024 年将达到 140 亿美元,并将在预测期内以 23.4%的年复合增长率增长。


作为一种云原生的架构,Serverless 与 BaaS、FaaS 之间有何“爱恨情仇”?冤家路窄却能完美解决前后端联调等开发痛点,解决方案又是如何?相较于传统开发模式,基于“无服务开发”理念的小程序·云开发模式又“新”在何处,有何利好?下面我们从 Serverless 的架构演进来具体分析。

Serverless 架构详解

在过去的十几年里(2006 年诞生 IaaS),云计算的进程从物理机演进到 IaaS,再到 PaaS,已经将应用程序的运行环境和通用组件,越来越多地交给云服务商。Serverless 进一步将主机管理、操作系统管理、资源分配、扩展、甚至应用逻辑的整个组件,都交付给云服务商,在成本和运营效率方面获得了显著的提升。


作为一种云原生的架构,Serverless 使得开发者在开发应用时不需部署、配置和管理传统服务器,转而依赖于第三方服务,将代码托管到云端平台。目前,业界并没有给出明确的定义,而是把其分成两种类型,分别为“Backend as a Service” 和 “Functions as a Service”。换一种开发者更熟知的表达方式看,也就是后端即服务(BaaS)和功能即服务(FaaS)。



Serverless=Baas+Faas?听着很高深,其实很好理解。


BaaS 是将应用开发中所有后端的需求,通过统一的云平台来解决,让开发者无需再编写和管理所有服务端组件。BaaS 使开发者无需编写完整的逻辑组件,但需要将应用程序与云服务商提供的特定接口和模型集成。


而 FaaS 是把函数作为一个线上服务、远程计算服务,可以通过 API、邮件、IoT 等执行。FaaS 是一种构建和部署服务端软件的新方式,面向部署单个的函数或者操作,是一种新的运行代码的托管环境。FaaS 本质上是事件驱动的,优化了函数运行时的资源使用,它的目标是在运行的时候才消费资源。


差异BaaSFaaS
技术框架应用基于API集而构建。事件驱动模型。它的部署方式更加细粒度,且需要将状态保存到FaaS组件之外。
应用场景为移动应用开发者提供后端云服务,包括云端数据/文件存储、账户管理、消息推送、社交媒体整合等。让开发者只需要上传代码而无需提供和管理服务器,由FaaS负责代码的执行、高可用扩展、应用直接调用等。除了提供一个平台保存和执行代码,FaaS供应商还会将各种同步和异步事件源集成起来。


从表面上看,BaaS 和 FaaS 是两码事——前者是把应用中的各个部分完全外包出去,后者是一种新的运行代码的托管环境。那么,为什么要把它们都划归为 Serverless 呢?关键在于,它们都不需要开发者管理自己的服务器主机或者服务器进程。Serverless 并非是无服务器,它仍然涉及服务器,只是这个服务器在云上。实际上,这是一种使用服务的新方法,在很多情况下,它比自己去买服务器更为划算,而且加快了项目上线的时间,降低了开发、维护、扩展的复杂性。


Serverless 技术的崛起不但让开发者无需过多考虑服务器问题,并且完美地解决前后端联调等开发痛点,作为一种全新的架构,Serverless 可谓是云计算发展演化的必然结果。

传统开发痛点解析及解法

“Serverless 所提供的接口,简化了云计算的编程,其代表了程序员生产力的又一次的变革,一如编程语言从汇编时代演变为高级语言时代。” 2019 年,伯克利在《将云中的编程变得简单:伯克利视角下的 Serverless 计算》中的犀利语句也论断了 Serverless 云时代主宰般的地位。


此前,云计算服务并没有从根本上改变设计应用程序的方式。


例如,当使用 Docker 这样的工具时,开发者在应用程序周围放置了一个更薄的“盒子”,但它仍然是一个盒子,逻辑架构不会发生显著的变化。再比如,在云中托管 MySQL 实例时,开发者仍需考虑工作负载所需的虚拟机资源,以及故障切换等问题。


现如今,这种情况在 Serverless 面前,迎刃而解。甚至在前后端分离与联调所产生的一系列权责、沟通与调试等开发痛点上,Serverless 也能从以下 5 个维度完美解决:


  • 按需计费。不同于 IaaS/PaaS 预先分配计算资源的计费方式,Serverless 按请求次数及运行时间计费,一方面可以最大程度利用资源,另一方面真正的按需计费可以降低开发者的资源成本,开发者只需要为函数实际执行所消耗的资源付费,即用即付;

  • 高效率。在 Serverless 的架构中,用户操作的是服务化的组件,如存储服务、授权服务等,缩短了开发周期,降低了开发难度,且避免了由基础设施产生的延迟;

  • 绿色计算。在 Serverless 架构下,服务商提供细力度的计算能力,最大限度地满足开发的实时需求,资源利用率将大幅度提升;

  • 高扩展。Serverless 架构的横向扩展是完全自动、有弹性的,且由服务提供者所管理;

  • 无需运维。运维的发展经历了人肉运维、自动化运维、DevOps 和 AIOps 等阶段,而 Serverless 带来一种新的运维模式。在这种模式下,开发者只需要关心业务本身,无需运维。


正因开发痛点重重,在想要突破传统开发模式,探索新型开发方案的过程中,开发者借助 Serverless 技术架构,基于“无服务开发”理念创造出了一种新型开发模式——小程序·云开发。


小程序·云开发,是微信与腾讯云联合开发的原生 Serverless 云服务,它集成了微信公众平台及腾讯云两个核心业务的技术能力,免鉴权、免后端配置和运维、一切围绕 API 和 SDK 为核心。


以云调用功能为例,只要在小程序端触发云函数,便将经过微信自动鉴权直接调用,如数据分析、客服消息,插件管理等开放 API 接口。这些开放接口通过系统配置、将大幅提升效率、优化体验、降低运营成本。



那么,在用户量峰值过大或黑客攻击的情况下,小程序·云开发是如何保证后台服务性能与安全的呢?首先,小程序·云开发没有传统的后台服务器,也就没有被 DDoS 的目标,这是从产品形态上保障用户业务安全;其次,小程序·云开发之间的环境是互相隔离的,即便发生攻击,从架构上将不会相互影响;再次,小程序·云开发服务构建在腾讯云基础设施之上,天然拥有快速扩容和安全防护的能力。


在用户量突增时,小程序·云开发的开发人员会立即通过响应的监控及告警发现流量的变化,然后确认是否需要扩容。腾讯云基础运维能力也保证了开发者拥有能够快速扩充服务的能力,以避免对用户的服务造成影响。


而在突发黑客大流量攻击(如 DDoS)时,小程序·云开发的开发及运维人员也会先确认遭受攻击的真实性,当得到确认后会第一时间与腾讯云系统运维、腾讯安全中心确认,确保已经对小程序·云开发的服务器加强防护,以保护系统服务安全。此外,小程序·云开发控制台也有响应的流量实时数据告知开发者,开发者可以据此了解服务的流量数据,如有异常可以联系小程序·云开发官方。

小程序·云开发架构详解

云开发是一种 BaaS,在引入了 Serverless 技术架构的同时,让开发者在构建应用的过程中无需关注计算资源的获取和运维。在应用端,开发者可以直接使用官方提供的接口。在云函数端,开发者可以直接使用官方提供的 Node SDK,来操作云资源。



目前小程序·云开发一共提供了三大基础能力,分别是云函数、数据库、文档存储。简而言之,就是提供了存文件、存数据和运行业务逻辑的能力。


其中,云函数能力来源于腾讯云的“无服务器云函数 SCF” 。通过与 SCF 的深度结合应用,可以形成一套比较完整的 Serverless 解决方案。


  • 使用 SCF,可以让开发者更简单的管理服务端代码,无需管理或配置服务器,只需将代码上传至 SCF,就可以自动运行;

  • 可以更高效的利用资源,按照执行时间和调用次数收费,代码不运行时不产生费用;

  • 可以快速建立持续扩展的能力,每个云函数互不影响,并行处理不同的逻辑。


此外,小程序·云开发的数据库能力则是基于腾讯云的 NoSQL 数据库服务,并兼容 MongoDB 协议。每个数据库资源都会分配一个实例 ID,每一个实例都是至少一主一从的副本集或者包含多个副本集的分片集群,数据库反向代理转发请求去最优副本集。


同样,小程序·云开发借助腾讯云提供的面向非结构化数据——对象存储(Cloud Object Storage,COS)支持文档存储服务的文件上传、下载和删除等功能,可以帮助开发者处理文件相关的业务逻辑。所有上传的文件都会有一个全网唯一的文件 ID,使用文件 ID 可以在 image、audio 等小程序组件中直接访问文件。通过小程序·云开发上传的文件在小程序内默认允许访问,不需要配置 CDN 域名白名单。


2019 年 1 月,腾讯云宣布推出总价值超过 10 亿元的“小程序·云开发”资源扶持计划,对超过一百万个小程序开发者提供免费资源扶持,全面助力开发者打造优秀小程序。


小程序·云开发将持续丰富 SDK 能力,释放腾讯的技术价值,逐渐支持多种开发语言,让开发更便捷。不仅如此,腾讯云还会加快丰富云开发的各类行业解决方案,满足企业业务不同应用场景需求 。


未来,新的技术层出不穷,但是要知道技术始终是为人服务的。不解决人的问题,技术无法成长壮大。将开发者的精力解放出来,让他们投入到业务逻辑等更具价值的工作中,从根本上赋能技术发展,才是推动行业”车轮“不断向前驶进的源动力。


2019-05-30 12:309326
用户头像

发布了 35 篇内容, 共 21.8 次阅读, 收获喜欢 43 次。

关注

评论

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

推出全新分布式计算接口!OneFlow v0.7.0发布,LiBai代码库、Serving、MLIR一应俱全

OneFlow

人工智能 机器学习 深度学习 深度学习框架 深度学习编译器

在 Kubernetes 中使用 Keycloak OIDC Provider 对用户进行身份验证

Se7en

使用APICloud AVM框架封装app日历组件

YonBuilder低代码开发平台

前端开发 APP开发 APICloud 多端开发 avm.js

如何利用MHA+ProxySQL实现读写分离和负载均衡

华为云开发者联盟

MySQL 读写分离 高可用架构 ProxySQL MHA

解析天翼云IPsec VPN和SSL VPN的区别

天翼云开发者社区

vpn

自动搭建Maven私有仓库,不限容量、免费用

阿里云云效

maven 阿里云 云原生 Maven仓库 制品仓库

eBPF Cilium实战(1) - 基于团队的网络隔离

北京好雨科技有限公司

Kubernetes PaaS rainbond

Android技术分享| 安卓3行代码,实现整套音视频通话功能

anyRTC开发者

android 音视频 移动开发 实时通讯 视频通话

天翼云云主机快照、云硬盘备份、云主机备份之间的区别

天翼云开发者社区

云主机 云备份

ModStartCMS Laravel9 v3.6.0内容标签增强,电脑手机适配

ModStart开源

快来一起玩转LiteOS组件:Curl

华为云开发者联盟

LiteOS 文件传输 curl LiteOS组件 嵌入式设备

社交CRM系统解决方案

低代码小观

CRM 企业管理系统 社交软件 CRM系统 客户关系管理系统

巧用天翼云盘备份云主机数据

天翼云开发者社区

云主机 云存储

「技术人生」专栏作者来直播间啦!欢迎来提问

阿里巴巴中间件

阿里云 云原生 中间件 技术人生 一号位

如何有效的对云专线进行测速

天翼云开发者社区

网络

Masa Blazor in Blazor Day

MASA技术团队

C# .net 微软

天翼云CDN最佳实践

天翼云开发者社区

CDN

OpenHarmony 3.1 Beta版本关键特性解析——ArkUI开发框架canvas组件绘制实践

OpenHarmony开发者

canvas OpenHarmony ArKUI 3.0

TASKCTL调度服务平台节点管理

TASKCTL

数据仓库 kettle 元数据 ETL任务 任务调度

三高Mysql - Mysql索引和查询优化(偏实战部分)

懒时小窝

MySQL

谈谈Java8-18引入的新特性

CRMEB

实例带你掌握如何分解条件表达式

华为云开发者联盟

代码 函数 条件表达式 条件分支 条件逻辑

Go 1.18 新特性:多模块工作区模式

华为云开发者联盟

Go 指令 go 1.18 多模块工作区 工作区

安全网关是啥什么东西?有什么优势?与堡垒机的区别是什么?

行云管家

网络安全 堡垒机 运维审计 安全网关 堡垒机防火墙

到底为什么你我都要了解社会工程学

图灵教育

黑客 社会工程 社会科学

【等保】等级保护定级对象只定信息系统吗?还是说定单位?

行云管家

网络安全 等保 等级保护 等保2.0

10元自助洗车机器多少钱一台?

共享电单车厂家

自助洗车机价格 10元自助洗车机器 自助洗车机器多少钱

DapuStor大普微电子加入PolarDB开源数据库社区

阿里云数据库开源

数据库 阿里云 开源数据库 polarDB

jackson学习之一:基本信息

程序员欣宸

4月月更

一文解读GPU服务器!

Finovy Cloud

人工智能 GPU服务器 GPU算力

郑曌:从 ACM 世界冠军到技术 VP 的制胜之道

第四范式开发者社区

人工智能 数据库 编程 程序员 ACM

热度3年猛增20倍,Serverless & 云开发的技术架构全解析_服务革新_一点小小苏_InfoQ精选文章