开发者必读!小程序后端技术你需要了解下

今天讲的是怎么使用Serverless做后端技术分享 。我的职业偏向是后端,可能不是写前端,不是使用Node.js , 更多是使用CR做后端语言,今天关注的微信小程序,我这一块的分享更多是怎么实现它的后端 。我所使用的是Serverless技术,也是在近两年新出来的一种架构 。讲Serverless这个架构之前 , 我也给大家讲一下小程序和传统的后台技术 。
目录
小程序的后台技术
小程序,是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验 。它的加载方式比传统的APP方式更快速上线 , 体验也不差 , 除了它本身的界面展示和刷新之外,小程序里面的数据获取通过微信和后端进行交互,小程序的运行实际上是一个类前端的运行方式,整个运行是在微信内,它和后端的交互实际上通过微信进行转发的,运行起来之后,它会提出一个api的请求,这个请求首先给到微信,微信再通过网络apr转到你自己的服务器上,服务器拿到这个请求以后进行数据的处理,然后再响应到前端,这就是小程序和后台交互的一种架构 。
微信小程序后台架构
对于后端服务 , 这张图是大家传统做的方式,暴露api,这些都可以用来开发业务应用,业务应用之后需要有相应的存储文件开发微信小程序需要多长时间,结构化的数据存储,或者是非结构化的数据存储,需要有数据库和缓存,为了实现这一套架构且不会由于某一块的服务器宕掉,或者有一些漏洞等等,我们通常的实现是一个较为复杂的过程 。比如说 , 我们为了保证的Serverless和服务器不会垮掉,需要建立一个集群,我们要对外提供服务,需要LB的请求,请求到之后分到某一台服务器上 。比如说文件存储 , 如果单纯只用一台设备,这台设备挂了,整个文件服务就挂了 , 所以我们要使用分布式存储来解决文件存储的问题 。数据库和缓存也是一样的,需要构建集群,无论是两台还是三台还是多台,构建集群以后能确保不会由于某一个单点的问题导致整个服务不可用 , 从而导致服务瘫痪 。
传统后台架构
传统后台架构
如果作为一个小程序开发者,这套架构在互联网公司已经搭建了,作为个人来说这一道太重了,需要了解这里面的某一块和它的配置,比如说数据库的集群怎么配?让大家没法把精力集中到你的业务和小程序本身,而是过多耗在运维和支撑上 。
Serverless架构
Serverless架构
我下面要介绍的Serverless架构,采用无服务器的方式 , 主要会介绍无服务器和云怎么结合,怎么利用云的服务减轻架构化的工作 。介绍它的架构之前,我介绍一下Serverless架构 , 英文称之为Serverless,中文称之为无服务器 , 大家不用购买服务器,不用购买虚拟机或者物理机,这一块怎么运行呢?它使用计算托管的方式,在Serverless这里,我们可以看成两块 , 第一块就是函数即服务,它真正实现了你业务的托管计算 。另外一种是后端即服务,包括对象存储 , 大家不用自己构建分布式存储,不用担心数据的丢失和安全性问题;同时在云上提供的数据库,消息队列和对象存储都是一样的,不用购买服务器自己搭建,在购买使用的过程当中我们可以称之为Serverless 。因为这些都是托管型的,使用的时候不用关心它的安全性 , 不用关心可能服务器宕机导致的故障 。
Serverless架构
Serverless的计算托管式云在服务函数内,下面来讲一下云函数的架构 。大家看到这个架构以后,我们后面在拿一个实际案例来看怎么把具体的api服务落地 。云服务器架构本身是计算托管型的,计算托管意味着把真正的业务代码托管到云上面,然后在云上面运行,它的运行方式有一个特点是触发式运营开发微信小程序需要多长时间,跟各个产品打通以后,各个产品产生的事件,后面的案例就是和API网关进行结合,从api网关来的事件就是api事件 , 当这个请求到达api网关时,我们就认为是一个事件,然后再运行 。大家最初进行托管的时候,把代码和触发期的配置提交到云上面来,并不是说提交之后代码就运行起来,而是事件到达才运行起来,代码对这个事件进行处理 。在这个过程中,对于每一次的事件 , 每一个代码拉起的过程,实际上都是单独处理一个事件,为什么呢?因为我们在这儿使用并发的模式,如果你有上万个用户同时访问你的小程序,要同时对上万的用户进行服务 , 启动上万的实例,它是在事件时运行起来,没有事件不能运行,这与微信小程序本身点开即用、用完即走的概念是符合的 , 有请求时才运行,没有请求时不运行 。产品的计费模式也是根据实际运行的时间计费的 。
Serverless的使用

开发者必读!小程序后端技术你需要了解下

文章插图
Serverless的使用
怎么使用Serverless呢?传统的架构就是前面说的web服务,然后是使用存储、缓存,我们对外服务以后,有对外暴露相应的api,实际上用户的业务逻辑都是放在云函数内,需要结构化存储,需要进行缓存或者对象存储,我们需要数据服务或者云缓存服务等 , 其他的服务都可以直接在线服务,这些服务直接通过代码调用 。
前面讲了Serverless的架构介绍,后面是对于这个后台开发的介绍,后面也是基于这个方式进行详细案例的说明 。
serverless后台开发方案
小程序除了本身的页面启动,后续与网络的交互都是由小程序发起,经过微信本身以后,首先请求到达api网关,对于对外的api的管理,把这个api暴露到官网上,可以被要程序访问得到 。它本身也能够提供api的发布和版本的切换能力,api网关之后就是云函数 。云函数就是实际处理业务的逻辑,如果你需要使用数据库,就在代码内发数据库的连接,需要存储文件,就调用相应的窗口写文件 。
基于这个方案我们来看一下,传统提供的是中间的一块,因为前端是用户的小程序,后端是微信本身提供的接口服务,中间建议的是开发者自己的服务器 。我们现在要展示的一个案例,也就是怎么把中间的开发者服务器替换掉,用Serverless的方案落地,我们使用了api网关加云数据库实现开发者服务器所能够做到的事情 , 不需要购买服务器而落地我们的api 。
首先从最前面的小程序来看,这个案例也是小程序开发者上面的demo,demo的前端包括登陆端口,以及session展示 , 我们在小程序这端首先获取一个talk,开发者拿到以后再跟微信交互 , 验证合法以后,我们这里选择了记录到云数据库,这就是小程序界面提供点击登陆的位置,后面的业务会发送请求到云上面来 。
对于这个小程序的核心,我们在某一个api上面的路径就是在hos的login url上发起GET操作,根据Wx.login构造请求的头部,body内容 , 发送获取到的code及加密数据到后台 。
用户示例
api网关
我们看一下api网关做的事情,它对外以一个api的接口呈现出来 , 我们直接提供了对外访问的域名,用户基于这个域名绑定自己所拥有的域名,这种情况下可以实现发布的要求 , 微信小程序的开发者要求域名要备案,把自己的域名绑定到api的服务上面来,对外提供,在右侧api的网关上,配一个/login Get,在后台还未实现之前,可以配置为mock方法,解耦前后端,小程序可以基于api构造的mock数据开发 。实现云函数后,对接api到云函数并更新发布api,避免开发的同时影响到在线业务 。
云函数的处理流程
云函数的处理流程之后,下面展示的是我们怎么和数据库建立连接,登陆信息的细节流程,创建连接并可复用连接,拼装SQL语句并执行 。
数据库的配置
这个地方就是我们购买以后,数据库启动并且做了登陆以后,可以进入到数据库里面查看数据,查看session的记录 。
实操案例——用户登陆及session展示
创建并初始化实例,按照mysql标准化使用方式操作 , 计算托管式的优势用户关心核心的代码,不用关心周边的运维,由于托管式业务,无论是个人请求,个人开发者的小程序,很有可能你的一个小程序就成为爆款,爆款以后可能访问量就是突增的形式 。
我们利用session的架构实现小程序,而且不用去担心运维;秒级启动,弹性计算能力满足用户上万的并发 。核心点关注业务代码 , 而不用关注web,这就是快速的应用实现小程序的落地的方法 。
【开发者必读!小程序后端技术你需要了解下】本文到此结束,希望对大家有所帮助!

猜你喜欢