简介:EMAS Serverless是阿里云一站式应用研发平台EMAS旗下的一款子产品,是面向小程序场景提供的Serverless开发、运营套件,开发者无需关心服务器和进行底层设施运维,专注于代码逻辑和业务本身,具备极简运维、多端适配、按需使用、弹性扩容等优势,帮助开发者快速部署小程序,本文将带你全面了解EMAS Serverless小程序开发,另附电子书《五天玩转EMAS Serverless》免费下载!!
\>> 快来免费下载|电子书《五天玩转EMAS Serverless》 <<
EMAS Serverless 是什么
EMAS Serverless 是阿里云提供的基于 Serverless 技术的一站式后端开发平台,为开发者提供高可用、弹性伸缩的云开发服务,包含云函数、云数据库、云存储、静态网站托管等功能,帮助开发者及企业客户快速实现一云多端应用的搭建,您无需管理服务器等基础设施,便可以无缝对接丰富的云资源。
图1 EMAS Serverless 产品架构
EMAS Serverless 应用场景
ES 支持云函数、云数据库、云存储等能力,具有弹性伸缩、按量付费、 免运维三大特点。弹性伸缩让您免于频繁运维扩缩机器,轻松应对各种流量突发事件,为您节省大量时间。按量付费做到用多少付多少,函数计费精确到毫秒,为您节省大量开支。免运维让开发者不用花费更多的精力在服务器等底层资源上,而是可以将精力放在更具价值的业务逻辑上。因此 ES 广泛适用于电商、咨询、旅游、企业展示、社区、餐厅等行业场景。
图2 EMAS Serverless 应用场景
开通产品
首先打开 EMAS 阿里云控制台: [https://emas.console.aliyun.com](https://emas.console.aliyun.com)
,新建并进入项目。然后选择平台服务并创建一个服务空间。如图3和图4所示:
图3 EMAS 控制台首页——项目管理
图4 选中平台服务并创建服务空间
计费方式
支持按量付费和包年包月两种付费方式。
- 按量付费(后付费):一种后付费模式,即先使用再付费。一般适用于有爆发业务量的应用或服务。
- 包年包月(预付费):一种预付费模式,即先付费再使用。通过包年包月,您可以提前预留资源,同时享受更大的价格优惠,帮您更大程度节省支出。
按量付费
模块 | 计费项 | 单价(按量付费) |
云函数 | 资源使用量(GBs) | 0.000110592 |
调用次数(万次) | 0.0133 | |
出网流量(GB) | 0.8 | |
云数据库 | 容量(GB/天) | 0.07 |
读操作数(万次) | 0.015 | |
写操作数(万次) | 0.05 | |
云存储 | 容量(GB/天) | 0.0043 |
下载操作次数(万次) | 0.01 | |
上传操作次数(万次) | 0.01 | |
CDN流量(GB) | 0.18 | |
静态网站托管 | 容量(GB/天) | 0.0043 |
CDN流量(GB) | 0.18 |
套餐规格 | 价格(元/月) | 套餐描述 |
开发者版 | Free | 适合练习、项目开发、启动初期使用。 |
基础版 | 5 | 我们提供了多种规格的套餐,您可以基于业务规模、项目发展阶段按需选择,并伴随业务的增长进行套餐升配。 |
标准版 | 24 | |
专业版 | 82 | |
企业版 | 316 | |
旗舰版 | 688 |
`
npm install --save @alicloud/mpserverless-sdk `
微信或者支付宝小程序还有一些特殊配置,具体请参考:https://help.aliyun.com/document\_detail/444395.html ## 初始化 SDK 在小程序端开始使用 Serverless 服务前,需要先调用 mpserverless.init
方法完成服务的初始化,且仅能初始化一次。较为通用的做法是在 onLaunch
生命周期中进行初始化操作,并将实例对象 mpserverless
挂载到小程序的全局对象 App
,以便后续在其他文件中调用。 这里演示使用的是匿名初始化,这种初始化方式无需在支付宝开放平台配置密钥,不过同时也无法获取小程序用户身份。更多细节请参考:https://help.aliyun.com/document\_detail/444402.html `
// app.js import MPServerless from '@alicloud/mpserverless-sdk' const mpserverless = new MPServerless(my, { appId: '小程序 AppID', spaceId: '服务空间 SpaceId', clientSecret: '服务空间 Secret', endpoint: '服务空间 API Endpoint' }); App({ mpserverless: mpserverless, onLaunch() { mpserverless.init( authorType: 'anonymous' ); }, }); `
## 云函数 云函数(FaaS)是一段运行在云端的、轻量的、无关联的并且可重用的代码。无需管理服务器,只需编写和上传代码,即可获得对应的数据结果。云函数的入参只有一个 ctx
对象,出参结构由开发者自行定义: `
// 云函数入口定义在 index.js 中 module.exports = async ctx => { // do something return result } `
### ctx
对象结构
字段 | 类型 | 含义 |
ctx.args |
Object? | 开发者通过 SDK 调用云函数时传入的参数体。例如:mpserverless.function.invoke( 'function-name', args )HTTP 触发和定时任务触发的入参结构稍有不同,请参考官方文档。 |
ctx.logger |
function | 日志工具,可以打印不同类型的日志信息,然后在云函数控制台中查看执行日志。
|
ctx.mpserverless |
SDK | 在云函数中为您提供已经完成初始化的 mpserverless 对象,让您可以继续调用 Serverless 其他基础服务,API 使用方式和客户端基本一致。 |
ctx.env |
Object | 在云函数中通过 ctx.env 来获取环境参数,例如 SpaceId、调用来源、客户端源 IP 和客户端 UserAgent 等信息。
|
ctx.httpclient |
HttpClient | 通过该对象可以请求任何HTTP和HTTPS协议的Web服务。例如:ctx.httpclient.request( 'https://*' ) |
TwoNumOperation
为例: `
// index.js module.exports = async ctx => { const { action, x, y } = ctx.args; let result = 0 switch (action) { case '+': result = x + y; break; case '-': result = x - y; break; case '': result = x y; break; case '/': if (y === 0) { throw new Error('cannot divide by 0') } result = x / y; break; default: throw new Error('not support action ' + action) } return { result } } `
新建文件夹 TwoNumOperation
,然后在文件夹下面新建文件 index.js 并放入上述代码,然后整体打包该文件夹得到压缩文件 TwoNumOperation.zip 。如下图5所示: 图5 云函数代码包 如下图6所示,首先我们在阿里云控制台新建一个云函数 TwoNumOperation,函数名称必须和文件夹名称一致。然后将压缩好的代码包上传、部署。部署成功后可以在控制台测试运行,点击代码执行,输入函数执行参数即可运行云函数。点击日志可以查看云函数的执行日志,方便开发者调试。 图6 云函数部署、执行、日志查看 ### 在小程序中调用云函数 如图7所示在小程序中调用云函数。 index.axml
布局文件简单写了一个表单包含三个 input,绑定表单提交函数 invokeFunction
。 index.js
文件首先从全局导入 mpserverless
对象,然后在表单提交函数中获取参数 action
、x
、y
,然后通过 mpserverless.function.invoke
调用云函数。 图7 在小程序中调用云函数 ## 云数据库 云数据库服务是基于 MongoDB 托管在云端的数据库,数据以 JSON 格式存储。作为开发者,您可以在客户端或者云函数中通过 mpserverless
对象读写数据。 `
mpserverless.db.collection('user').findOne( { name: '张三' } ) `
### 和 MySQL 对比 ES 云数据库服务底层使用的是 MongoDB,以 JSON 格式存储数据。数据库中的每条记录都是一个 JSON 格式的文档,一个数据库可以包含多个集合(相当于关系型数据库中的表),每个集合可看做一个 JSON 文档数组。MongoDB 数据库和关系型数据库 MySQL 的对比如下表所示。
云数据库 (MongoDB) | 关系型数据库 (MySQL) |
数据库(database) | 数据库(database) |
表(collection) | 表(table) |
记录(document) | 行(row) |
域(field) | 列(column) |
索引(index) | 索引(index) |
自动将_id字段作为主键 | 主键(primary key) |
`
{ "id": 5573, "name": "Egg T恤", "desc": { "short": "限量版 Egg T恤,穿上它你离极客也不远了", "long": "这是一段非常长的描述", "category": { "_id": "48bf43a..29e90bc", "name": "上衣" } }, "attributes": [ { "id": 1151, "name": "尺寸", "values": [ { "id": 3871, "value": "S" }, { "id": 3874, "value": "M" }, { "id": 3875, "value": "L" } ] }, { "id": 1152, "name": "性别", "values": [ { "id": 3872, "value": "男" }, { "id": 3873, "value": "女" } ] } ], "sku": [ { "id": 1153, "stock": 30, "attributeIds": [ 3871, 3872 ], "attributes": [ { "key": "尺寸", "value": "S" }, { "key": "性别", "value": "女" } ] } ] } `
### 创建数据表 在阿里云控制台上点击“+”新建数据表 图8 在控制台新建数据表 ### 添加数据记录 #### insertOne 插入用户张三 `
mpserverless.db.collection('users').insertOne( { name: '张三', age: 18 } ) `
#### insertMany `
mpserverless.db.collection('users').insertOne( [ { name: '张三', age: 18 }, { name: '李四', age: 17 } ] ) `
### 删除数据记录 #### deleteOne `
mpserverless.db.collection('users').deleteOne( { name: '张三' } ) `
#### deleteMany 删除年龄小于18的用户 `
mpserverless.db.collection('users').deleteMany( { age: { $lt: 18 } } ) `
### 查询数据记录 #### findOne `
mpserverless.db.collection('users').findOne( { age: { $gt: 18 } } ) `
#### find 查询所有大于18的用户 name,并将查询结果按年龄升序返回 `
mpserverless.db.collection('users').find( { age: { $gt: 18 } }, { projection: { name: 1 }, sort: { age: 1 } } ) `
#### findOneAndDelete 查询并删除小于且最接近18岁的一条数据 `
mpserverless.db.collection('users').findOneAndDelete( { age: { $lt: 18 } }, { sort: { age: -1 } } ) `
#### findOneAndReplace 查询并替换 name 为张三的一条数据 `
mpserverless.db.collection('users').findOneAndReplace( { name: "张三" }, { name: "张三三", age: 20 }, { upsert: true // 如果不存在则插入 } ) `
#### findOneAndUpdate 查询并更新 name 为张三的一条数据 `
mpserverless.db.collection('users').findOneAndUpdate( { name: "张三" }, { $set: { name: "张三三", age: 20 } }, { upsert: true // 如果不存在则插入 } ) `
### 更新数据记录 #### updateOne 更新第一个张三的年龄为22岁 `
mpserverless.db.collection('users').updateOne( { name: "张三" }, { $set: { age: 22 } } ) `
#### updateMany 把所有的张三年龄都设置为22岁 `
mpserverless.db.collection('users').updateMany( { name: "张三" }, { $set: { age: 22 } } ) `
#### replaceOne 把第一个张三姓名改为张阿三,年龄改为22岁 `
mpserverless.db.collection('users').replaceOne( { name: "张三" }, { $set: { name: '张阿三', age: 22 } }, { upsert: true // 如果不存在则插入,为 flase 时代表不存在则不做任何操作 } ) `
### 其他指令 #### distinct 返回 age 字段大于18的所有姓名(如果有相同的name 只返回一个) `
mpserverless.db.collection('users').distinct( 'name', { age: { $gt: 18 } ) `
#### count 查找集合 users 中所有 age 大于18的记录数量 `
mpserverless.db.collection('users').count( { age: { $gt: 18 } } ) `
#### aggregate 聚合管道查询,该管道允许用户通过一系列基于阶段的操作来处理数据,详情请参考帮助文档 https://help.aliyun.com/document\_detail/435909.html ## 云存储 mpserverless.file
对象提供 uploadFile
和 deleteFile
方法管理文件。上传的文件将通过CDN进行网络加速。单个文件要求小于100 MB。 ### 上传文件 支付宝小程序上传文件示例 `
my.chooseImage({ chooseImage: 1, success: res => { const path = res.apFilePaths[0]; const options = { filePath: path, }; mpserverless.file.uploadFile(options) .then(res => { console.log(res); }) .catch(err => { console.log(err); }); }, }); `
返回示例: `
{ "fileUrl": "https://mp-…storage/2e7acad6-2212-4863-aaa7-4e89d7d8df4c.png", "filePath": "cloudstorage/2e7acad6-2212-4863-aaa7-4e89d7d8df4c.png" } `
### 删除文件 根据文件地址从服务空间中删除该文件 `
const fileURL = 'https://mp...bspapp.com/xxx-x...'; mpserverless.file.deleteFile(fileURL) `
## 总结 EMAS Serverless 依托阿里巴巴数字经济技术能力和业务能力提供云函数、云存储、云数据库等 Serverless 服务。大大提升了前端工程师的价值,让开发者快速落地小程序开发工作,按量付费和自动弹性伸缩省时省力。此外, ES 还支持静态网站托管以及面向支付宝生态的云调用模块,技术与商业联动为开发者提供一站式地小程序生态服务。 ## 参考资料 EMAS 控制台:https://emas.console.aliyun.com 帮助文档:https://help.aliyun.com/document\_detail/436030.html 开发指南:https://help.aliyun.com/document\_detail/444395.html \>> 快来免费下载|电子书《五天玩转EMAS Serverless》 << > 版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。