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

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

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

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

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

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

  • 速度快。无需下载安装,加载速度快于 app HTML5,随时可用
  • 无适配。一次开发,多端兼容,免除了对各种手机机型的适配
  • 可分享。支持图文分享、支持分享给微信好友和群聊
  • 体验好。可达到近乎与原生 app 相同的操作体验和流畅度
  • 易获取。支持扫码、微信搜索、好友推荐等发起场景
  • 低门槛。基于微信的生态。已有公众号的组织可快速注册、可快速生成小程序

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

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

  • 基本能力:图片及视频获取、展示、管理、上传、下载、图片集
  • 社交属性:点赞、评论
  • 传播能力:分享
  • 用户规模:千万级
  • 上线时间:4 周。时间对于产品占领用户的心来说十分重要,因此,时间目标定了 4 周上线。

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

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

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

传统模式开发流程

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

  1. 项目人员准备:至少 1 个前端工程师,2 个后台工程师,加一个测试和 2 个运维
  2. 当人员 Ready 后,开始着手环境搭建,需要运维购买资源,如主机,数据库,负载均衡等,并协助部署运行环境、域名备案、搭建监控告警系统等。
  3. 环境 Ready 后,前端和后台开始开发,然后测试介入、运维完成线上部署,最后申请发布。

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

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

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

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

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

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

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

基于 Serverless 模式的开发流程

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

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

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

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

  • 首先云开发封装了用户需要用到的云函数、数据库和文件存储资源,开发不用再去关心环境问题;
  • 其次,从小程序端到云开发后台的请求,走的是微信和腾讯云之间的专线,并且用的是私有协议,所以用户也不用担心安全问题;
  • 最后,云开发整个后台提供了完善的监控和日志系统,也省去了运维同学的部分工作。因此,新的方案不仅省去了很多运维的工作,同时也有效的加速了开发流程。

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

如何使用

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

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

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

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

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

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

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

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

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

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

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

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

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

总结

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

  1. 加快了产品的迭代效率
  2. 稳定,高可用,弹性伸缩,完全不需要自己关心底层的运维
  3. 降低了资源的投入,这里包括了人力和财力

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

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

点击“了解更多”下载讲师完整 PDF。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2023年4月3日 上午10:14
下一篇 2023年4月3日 上午10:30

相关推荐

  • 课题立项新闻(学院科研项目立项的新闻稿)

    学院科研项目立项成功 近日,学院成功立项了一项具有重要前瞻性和实用性的科研项目。该项目由学院科研团队精心设计和策划,旨在深入研究和应用人工智能在医疗领域的应用,为未来的医学发展做出…

    科研百科 2024年4月11日
    86
  • 建设单位对施工、监理单位的考核检查办法

    建设单位对施工、监理单位的考核检查办法 在房屋建筑和工程领域的实践中,建设单位是房屋建筑和工程的决策者和监督者。建设单位负责监督施工和监理单位的工作,确保房屋建筑和工程的质量和安全…

    科研百科 2024年12月7日
    0
  • 澳国立项目管理硕士

    澳国立项目管理硕士: 项目管理领域的辉煌成就 澳国立项目管理硕士是澳大利亚最著名的项目管理专业之一。该项目成立于1994年,由澳国立大学管理系和澳大利亚项目管理协会共同创办。在过去…

    科研百科 2024年10月7日
    12
  • 项目管理 排名

    项目管理在现代社会扮演着越来越重要的角色。在这个快速变化和竞争激烈的世界中,优秀的项目经理能够帮助组织实现其目标,并在竞争中保持优势。今天,我们将对全球排名前十的项目管理公司进行排…

    科研百科 2024年5月26日
    73
  • 本科专业目录对照表2024

    本科专业目录对照表2024本科专业目录对照表20241.《中华人民共和国教育纲要》中的《中华人民共和国教育纲要》(简称《课程标准》)中的《教育纲要》(简称《课程标准》)中是按照我国…

    科研百科 2024年11月25日
    3
  • 企业内部控制的 7 大类控制措施(企业内部控制的 7 大类控制措施包括)

    企业内部控制的控制措施 企业内部控制的控制措施一般包括不相容职务分离控制、授权审批控制、会计系统控制、财产保护控制、预算控制、运营分析控制和绩效考评控制等。 1.不相容职务分离控制…

    科研百科 2024年5月10日
    94
  • 医药人必看!5款查询药品信息的APP测评(查药品信息查询的软件)

    不仅是医生在临床时需要查询药品信息,药企在筛选潜力品种或者进行竞争对手分析时也需要查询药品数据时,券商、证券分析师也需要及时了解医药行业动态信息以此了解市场竞争格局。 查询药品信息…

    科研百科 2023年8月27日
    1.7K
  • 药石 项目管理系统

    药石项目管理系统 药石项目管理系统是一种用于药品生产、销售和库存管理的软件系统。该系统可以帮助制药公司更好地管理其业务,提高效率,降低成本,并确保生产和质量的一致性。 该系统涵盖了…

    科研百科 2024年12月13日
    0
  • 医学科研项目风险防范及措施医学科研项目风险防范及措施

    医学科研项目风险防范及措施 随着医学科学研究的不断发展,医学科研项目已经成为医疗机构的重要工作之一。然而,医学科研项目中的风险也不容忽视。本文将介绍医学科研项目中常见的风险以及如何…

    科研百科 2024年7月9日
    53
  • 科研诚信倡议书(科研诚信倡议书500字)

    诚信是科研工作之本、事业兴盛之基、做人做事之要,关乎强军事业。为贯彻落实习主席关于突出抓好科研诚信建设的重要指示精神,全面实施科技兴军战略,现发出如下科研诚信倡议: 一、保证科研数…

    科研百科 2024年4月8日
    94