NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

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:007208

评论

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

Vue进阶(三十六):created() 详解

No Silver Bullet

Vue 8月日更

docker介绍与安装

Rubble

Docker 8月日更

kubernetes/k8s CRI 分析 -kubelet 删除 pod 分析

良凯尔

Kubernetes 源码分析 Kubernetes Plugin #Kubernetes# cri-o

Vue进阶(三十七):created、mounted等钩子函数整理

No Silver Bullet

Vue 8月日更

fil币价格行情怎么样?fil币价值和未来在哪?

fil币价格行情怎么样 fil币价值和未来在哪

FastApi-13-文件上传-1

Python研究所

FastApi 8月日更

LeetCode题解:208. 实现 Trie (前缀树),对象,JavaScript,详细注释

Lee Chen

算法 大前端 LeetCode

架构实战营毕业总结

唐高为

Python开发篇——基于React-Dropzone开发上传组件

DisonTangor

Python flask React

HarmonyOS组件开发 ScrollView嵌套ListContainer 滑动冲突问题

爱吃土豆丝的打工人

HarmonyOS ScrollView ListContainer 嵌套滑动

如何在二三线城市月薪过万(三)java偏功能实现的面试题,有备无患!!

小鲍侃java

8月日更

Flutter Android 端 FlutterEngine Java 相关流程源码分析

工匠若水

flutter android 面试 8月日更

入职新公司后如何快速上手项目

咔咔

php MySQL 数据库

架构实战训练营总结

唐江

架构实战营

杂谈:电商平台中的图片资源优化实战

云小梦

CSS JavaScript html5 jpeg 图片处理

架构实战营毕业总结

Saber

架构实战营 毕业总结

Drools 规则属性

LeifChen

drools 规则引擎 8月日更 规则属性

智能边缘开源框架Baetyl,构建边缘融合智能应用

百度开发者中心

AI 最佳实践 物联网 边缘计算 开源技术

如何设计一个容错的微服务架构

架构精进之路

架构 微服务 8月日更

架构实战营 模块五作业

孫影

架构实战营 #架构实战营

架构实战营 | 毕业总结

架构实战营

Python Qt GUI设计简介、环境下载和安装(基础篇—1)

不脱发的程序猿

Python qt GUI设计 Qt Company

上游思维的三大障碍

石云升

读书笔记 8月日更 上游思维

极客大学架构实战0期毕业总结

谢博琛

财富自由的本质及如何实现财富自由?

非著名程序员

认知提升 个人提升 财富自由 8月日更

架构实战营 毕业总结

Ahu

JavaScript 中如何比较变量的相等

devpoint

JavaScript ES6 8月日更

模块五作业

Mr.He

架构实战营

netty系列之:对聊天进行加密

程序那些事

Java Netty nio

架构实战营模块五作业-微博评论高性能高可用架构

王晓宇

架构实战营

python爬取下载m3u8加密视频,原来这么简单!

Python研究者

8月日更

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