10 月 23 - 25 日,QCon 上海站即将召开,现在购票,享9折优惠 了解详情
写点什么

Serverless 最佳实践:如何在两周内开发出用户量过亿的微信小程序

  • 2019-07-01
  • 本文字数:2632 字

    阅读完需:约 9 分钟

Serverless最佳实践:如何在两周内开发出用户量过亿的微信小程序

一切好的产品都是从一个绝妙的创意开始!


腾讯相册前身是空间相册,而且空间相册已经在手机 APP 端,网页端都有了入口。为了增加用户活跃,让客户在各个软件中都能快速触达,腾讯相册团队推出了微信小程序形式的腾讯相册。本文将从开发背景、技术需求与落地实践三个维度出发,还原腾讯相册小程序的开发历程,以及 Serverless 是如何助力腾讯相册团队在两周内,开发出承载过亿用户量的微信小程序。


注:文章内容整理自腾讯云产品经理方坤丁和高级架构师卢萌凯在 Kubecon 2019 上的演讲,演讲主题为《Serverless 云上最佳实践 :如何在两周内开发出用户量过亿的微信小程序》,感兴趣的读者可点击阅读原文下载讲师完整 PDF。

腾讯相册微信小程序开发背景说明

在 2019 年 Q1,微信和 WeChat 的合并活跃用户为 11.12 亿,而小程序的活跃用户从 17 年初发布后,在 18 年底增长到了 2.3 亿。小程序主要有以下几个特点:


  • 速度快。无需下载安装,加载速度快于 app HTML5,随时可用

  • 无适配。一次开发,多端兼容,免除了对各种手机机型的适配

  • 可分享。支持图文分享、支持分享给微信好友和群聊

  • 体验好。可达到近乎与原生 app 相同的操作体验和流畅度

  • 易获取。支持扫码、微信搜索、好友推荐等发起场景

  • 低门槛。基于微信的生态。已有公众号的组织可快速注册、可快速生成小程序



微信小程序的这些特性,能够与腾讯相册这类社交性工具完美结合。那么,这个小程序应该怎样设计?作为一名产品经理,我们想到了如下几个需求:


  • 基本能力:图片及视频获取、展示、管理、上传、下载、图片集

  • 社交属性:点赞、评论

  • 传播能力:分享

  • 用户规模:千万级

  • 上线时间:4 周。时间对于产品占领用户的心来说十分重要,因此,时间目标定了 4 周上线。



需求明确之后,就是怎样用高效、快速并省成本的方式实现腾讯相册小程序。

腾讯相册小程序基于 Serverless 落地实践

传统模式开发流程

产品的开发需求非常明确,总结 4 个字就是“多快好省”。承载千万级用户的小程序,对后台架构的性能和稳定性要求非常高,如果有足够的时间和资源,这些都不是问题。但是想要在 4 周的时间内完成开发并上线,压力非常大。如果按照传统的开发模式下,这样一款小程序需要


  1. 项目人员准备:至少 1 个前端工程师,2 个后台工程师,加一个测试和 2 个运维。

  2. 当人员 Ready 后,开始着手环境搭建,需要运维购买资源,如主机,数据库,负载均衡等,并协助部署运行环境、域名备案、搭建监控告警系统等。

  3. 环境 Ready 后,前端和后台开始开发,然后测试介入、运维完成线上部署,最后申请发布。


即使顺利的情况下,整套流程都很顺利的走完,也需要至少 8 周的时间,如果人员不到位,需要的时间更久。可以发现,耗时主要是在环境搭建和开发流程当中,而且人力耗费也在这一块。



在开发流程这块,后端开发除了需要关注核心业务逻辑之外,还需要做框架选型,了解数据库和文件存储等。并且还需要耗费精力对性能进行优化,比如高并发。那么必然也要去了解底层的运行机制,比如容器服务。同时运维也要花大量的时间来保障安全和容灾等能力。



因此,自上而下,对团队成员的专业技能要求越来越高。同时,花费的时间也越来越多。


环境和开发工作全部完成后,需要进行架构维护,不仅需要维护业务集群,还需要关注各个组件的稳定性。测试方面,除了产品功能验证外,还需要压测各个组件的性能。最后,还需要随时保障整个系统的稳定性和安全性。


基于 Serverless 模式的开发流程

如果将刚才提到的和核心业务逻辑不相关的事情都交给微信和腾讯云,系统架构将会大大简化,而且能够节省不少人力。最终,只需要关注的只剩下小程序端+核心业务,整个开发流程将会变得无比简洁。通过 Serverless,这种想法可以得以实现。Serverless 其实是一种架构理念,他是把底层资源抽象成 API 的形式对用户提供服务。



在去年年初,微信团队和腾讯云团队开始尝试将 Serverless 和小程序开发结合起来并提供一套小程序 · 云开发解决方案,这还要归功于 Faas 在国内的兴起。有了 Faas 之后,用户核心计算逻辑的承载平台真正实现了 Serverless 化。



  • 首先云开发封装了用户需要用到的云函数、数据库和文件存储资源,开发不用再去关心环境问题;

  • 其次,从小程序端到云开发后台的请求,走的是微信和腾讯云之间的专线,并且用的是私有协议,所以用户也不用担心安全问题;

  • 最后,云开发整个后台提供了完善的监控和日志系统,也省去了运维同学的部分工作。因此,新的方案不仅省去了很多运维的工作,同时也有效的加速了开发流程。



如何使用


新的架构或者方案具体该怎么使用呢?之前有提到,整个方案里最核心的是计算模块。当有用户在小程序端发起后台请求的时候,云函数平台会根据用户的请求量动态的伸缩实例,以保证用户的请求能够被及时响应,同时用户可以在云函数里发起数据库以及文件存储的读写操作。下图展示的完整架构是 Serverless 的具体表现形式。用户不再需要部署服务器,通过无服务器云函数即可实现核心业务逻辑。



这一套基于 Serverless 的架构将会具备以下优势:1、无穷的弹性计算能力;2、让用户聚焦核心业务逻辑的编写;3、根据请求自动运行;4、秒级上传部署;5、几乎不需要运维运维。


如何基于 Serverless 实现腾讯相册小程序开发

以最核心的社交功能为例。按照传统的开发模式,研发团队会面临几个挑战,运维人力,开发复杂度,历史包袱等。



借助云开发的能力,架构设计将会变得非常简单。举个例子,按照传统的开发方式,需要花费大量的时间在框架路由设计和安全设计,以及后台的性能优化上面。而基于 Serverless 的方案,只需引用 SDK,就能直接 callfunction,运行业务代码。



再来看下性能方面,根据现网的运行数据,发现无论波峰还是波谷,后台的响应延迟都在 70ms 以下。



可以看到,对比传统的开发模式,需要大约 1 人 10 周的人力完成开发,而借助 Serverless,只需要 1 人 3 周就能完成基础开发和测试。因为,系统架构变的非常简单,并且和原有的空间后台完美兼容,极大的提升了开发效率。


总结

对于公司/个人来说,通过云的 Serverless 架构开发微信小程序,有下面几个非常显著的优势:


  1. 加快了产品的迭代效率

  2. 稳定,高可用,弹性伸缩,完全不需要自己关心底层的运维

  3. 降低了资源的投入,这里包括了人力和财力


腾讯云 Serverless,可以助力微信小程序开发!用户后续在开发小程序,或者有任何想法需要快速落地时,可以想到采用 Serverless 架构来开发 ,非常的惊喜、简单。


本文转载自公众号 ServerlessCloudNative(ID:ServerlessGo)


原文链接


https://mp.weixin.qq.com/s/zzdTAzpu2SUizelhGbzvDQ


2019-07-01 08:007725

评论

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

世界之书:《一个人的朝圣》与重归信仰

lidaobing

一个人的朝圣 28天写作

字典树 —— 字符串分析算法

三钻

算法 大前端 七日更 字典树

Prometheus的使用:编写自己的exporter

Rayzh

Prometheus 监控告警

后端缓存代码实践

Albert

缓存击穿 七日更

Nice!有了这份Alibaba内部 “Java面试宝典”,跳槽面试稳了

Java架构之路

Java 程序员 架构 面试 编程语言

数字资产币种钱包APP系统开发方案

计算存储分离在消息队列上的应用

京东科技开发者

大数据 云原生 中间件 消息中间件

【数据结构与算法】分析时间复杂度与空间复杂度

三钻

数据结构与算法

区块链钱包app系统开发源码案例

week5-homework-一致性哈希

J

极客大学架构师训练营

TypeScript | 第四章:命名空间和模块

梁龙先森

typescript 大前端 七日更

盘点2020 | 所思、所遇、所学、所悟

三钻

程序员 大前端 盘点2020

用 Range 实现 CSSOM 精准操作

三钻

大前端 Range 七日更 CSSOM

音乐后期处理:音乐失真效果制作

懒得勤快

音乐制作 编曲 编曲宿主 mid 音乐后期

万字详解 阿里面试真题:请你说说索引的原理

Java架构师迁哥

TARS RPC 通信框架|提供多种远程调用方式

TARS基金会

微服务 RPC 远程调用 TARS

有效破解行业难点 专家称区块链+医疗发展还需找准应用场景

CECBC

区块链 大数据 医疗

分布式缓存架构

raox

极客大学架构师训练营

四年Java开发,刚从美团、京东、阿里面试归来(已拿offer),分享个人面经

Java架构之路

Java 程序员 架构 面试 编程语言

摸透原理|一文带你了解 Redis 列表底层的实现方式

Java架构师迁哥

全国首张数字人民币保单成功出单

CECBC

数字人民币保单

Java并发编程:AQS的自旋锁

李尚智

Java java 并发

用 Proxy 简单实现 Vue 3 的 Reactive

三钻

Java 大前端 Vue3 Proxy 七日更

鹅厂面经,希望对大家有用

Bryant-cx

大前端 面经

TARS 服务信息上报|全方位服务监控

TARS基金会

微服务 TARS 监控告警

10万级ETL批量作业调度工具Taskctl-Web应用版0元授权永久使用

敏捷调度TASKCTL

大数据 kettle 运维自动化 海豚调度 批量任务

区块链和通证经济带来的,是一部分股份制公司的消亡与重生

CECBC

金融 通证经济

真香!阿里P8耗时半年著作660页Java高并发与网络编程实战总结

Java架构之路

Java 程序员 架构 面试 编程语言

使用LL算法构建AST —— 编程训练

三钻

Java 算法 大前端 七日更

阿里高工手码”537页Spring源码速成手册“3天直接带你飙向实战

比伯

Java 编程 架构 面试 计算机

第五课技术选型作业

Geek_michael

极客大学架构师训练营

Serverless最佳实践:如何在两周内开发出用户量过亿的微信小程序_架构_腾讯云中间件_InfoQ精选文章