迁移Node.js项目到阿里云函数计算 – 以Parse为例

简介: Parse是一款优秀的开源BAAS框架,可以快速支持初创项目迭代。本文将介绍如何结合阿里云函数计算快速部署一个私有的Parse服务。本文需要阅读者有基本的Serverless平台使用经验。

Parse Platform是一个开源的BAAS框架,可以大幅加速各类应用快速迭代。官方提供了各位常见SDK,对于开发者也可以缩短了应用的开发周期,实在没有的,还可以用Rest API。


之前Parse.Inc提供托管服务,但是由于各类原因关闭了,国内也有一些托管服务商。


Parse Platform基于Node.js,背后的数据库可以选择MongoDB或者PG,文件和PUSH服务可选很多。


自己搭建一个Parse是相当容易了,官方提供了命令行工具,也有Docker镜像,但是这种模式需要至少一台云主机和一个MongoDB数据库,相对来说有一定成本,特别是对于一些探索性的APP,流量低,访问需求不稳定,后期可能有突发流量。


综合来看Serverless平台是一个不错的选择,本文以阿里云为例,介绍如何快速基于阿里云函数计算和阿里云Serverless DB搭建一个Parse。


本文需要基本的Serverless平台使用经验。由于篇幅所限,本文只涉及最基本的跑起来,包括发布和数据库存储,文件存储和其他优化不涉及。


阿里云函数计算

阿里云函数计算是事件驱动的全托管计算服务。通过函数计算,用户无需管理服务器等基础设施,只需编写代码并上传。函数计算会准备好计算资源,以弹性、可靠的方式运行代码,另外还提供日志查询、性能监控、报警等功能。


使用函数计算可以获得一个较大的成本收益,也可以简化维护与运维成本。


函数计算的费用由调用次数+函数实例资源使用量+公网出流量组成,另外如果长期使用,

还可以购买资源包,相对价格更低。


阿里云每月为每个账号提供一定的免费资源,对于少量使用可以完全覆盖。


如何迁移


迁移一个既有系统到Serverless平台主要有以下几个步骤


  • 识别系统的外部依赖
  • 创建适用于Serverless平台的部署工程
  • 修改即有系统代码
  • 部署


识别外部依赖


Parse的外部比较简单,从官方文档的说明和配置示例可见


  • Node 8 or newer
  • MongoDB version 3.6
  • Python 2.x (For Windows users, 2.7.1 is the required version)


这些Serverless平台都可以提供。

但是对于数据库,特别是MongoDB在各大云厂商价格相对较高,好在阿里云额外提供了Serverless版本,价格相对优惠,新用户9.9元3个月试用。


aliyun-serverless-mongoDB.png


开通后可以在数据库连接中查到连接字符串,但是这里的连接字符串是不能直接用,因为它使用的是admin库,需要改成 /自定义库名?authSource=admin。


mongodb-connection-string_mosaic.png


创建Serverless工程


为了方便调试和开发这里使用Serverless Devs工具。


它是一个开源开放的Serverless开发者平台,开发者无需关心底层资源。通过Serverless Devs,不仅可以可插拔式地使用Serverless的服务和框架,也可以参与组件和插件的开发,提高运维效率。同时,您也可以更简单、快速地开发、创建、测试和部署项目,实现项目全生命周期的管理。


安装和创建项目如下:

npm install @serverless-devs/s -gs config
s init

这里我们选择express模版,最后会获取一个如下的项目

start-project.png


其中s.yaml是配置文件,定义了部署需要的一切信息,包括需要的内存大小、超时时间、触发器等等。由于Parse本身就是通告HTTP提供服务的,所以使用默认的HTTP触发器就可以了。其他信息可以按照需要修改。


适配项目

由于这里只展示最小应用,所以仅做最简单的配置

varexpress=require('express');
varapp=express();
varParseServer=require('parse-server').ParseServer;
varapi=newParseServer({
databaseURI: 'mongodb://xxxx/xxx',
appId: 'demo',
masterKey: 'demoKey',
});
app.use('/', api);
app.listen(9000, () => {
console.log('start success.');
}).on('error', (e) => {
console.error(e.code, e.message)
})


这个和普通的nodejs服务没有什么区别,其中的端口9000需要和s.yaml的CAPort配置一致就行了。


由于Rest API语义设计,需要支持GET、POST、DELETE等,阿里云函数计算这里存在一个转发问题,需要在配置文件中变更触发器


triggers:
-name: httpTriggertype: httpconfig:
authType: anonymousmethods:
-GET-POST-PUT-DELETE


阿里云函数计算默认的Nodejs版本有点低,也考虑到其他风险,这里最好也自定义Nodejs环境。直接下载linux版本的到code目录,修改bootstrap脚本内容为


#!/bin/bash./node-v12.13.0-linux-x64/bin/node index.js

这样就会使用我们指定的Node.js启动Parse了。


部署


部署可以直接使用

s deploy -y

会将相关资源打包以后上传到阿里云函数计算,也会包含node_module中的内容,这里的大小大概40M。

部署以后在函数计算管理界面可以看到。

fcnext.png


这里直接使用自带的测试URL测试,可以看到Parse工作正常。


serverless-parse-result_mosaic.png


结语


由于阿里云函数计算提供的便利支持,迁移此类项目的难度并不大。本文演示的是Custom Runtime的模式,但是对于更复杂的项目,Custom Container是一个更好的选择。


Serverless还有一个潜在问题就是冷启动时间,对于大部分项目都需要专门处理,本文并没有涉及到。简单粗暴的方式就是使用预留实例的方式保持有已经启动的实例在服务,可以极大优化用户体验。


参考

https://parseplatform.org/

https://help.aliyun.com/product/50980.html


相关实践学习
【AI破次元壁合照】少年白马醉春风,函数计算一键部署AI绘画平台
本次实验基于阿里云函数计算产品能力开发AI绘画平台,可让您实现“破次元壁”与角色合照,为角色换背景效果,用AI绘图技术绘出属于自己的少年江湖。
从 0 入门函数计算
在函数计算的架构中,开发者只需要编写业务代码,并监控业务运行情况就可以了。这将开发者从繁重的运维工作中解放出来,将精力投入到更有意义的开发任务上。
相关文章
|
12月前
|
弹性计算 JavaScript 前端开发
一键安装!阿里云新功能部署Nodejs环境到ECS竟然如此简单!
Node.js 是一种高效的 JavaScript 运行环境,基于 Chrome V8 引擎,支持在服务器端运行 JavaScript 代码。本文介绍如何在阿里云上一键部署 Node.js 环境,无需繁琐配置,轻松上手。前提条件包括 ECS 实例运行中且操作系统为 CentOS、Ubuntu 等。功能特点为一键安装和稳定性好,支持常用 LTS 版本。安装步骤简单:登录阿里云控制台,选择扩展程序管理页面,安装 Node.js 扩展,选择实例和版本,等待创建完成并验证安装成功。通过阿里云的公共扩展,初学者和经验丰富的开发者都能快速进入开发状态,开启高效开发之旅。
|
JavaScript Java Serverless
函数计算产品使用问题之如何使用Node.js编写程序
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
消息中间件 JavaScript 中间件
函数计算产品使用问题之WebIDE编写的Node.js代码是否会自动进行打包部署
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
12月前
|
弹性计算 JavaScript 前端开发
一键安装!阿里云新功能部署Nodejs环境到ECS竟然如此简单!
一键安装!阿里云新功能部署Nodejs环境到ECS竟然如此简单!
一键安装!阿里云新功能部署Nodejs环境到ECS竟然如此简单!
|
11月前
|
JavaScript Ubuntu Linux
如何在阿里云的linux上搭建Node.js编程环境?
本指南介绍如何在阿里云Linux服务器(Ubuntu/CentOS)上搭建Node.js环境,包含两种安装方式:包管理器快速安装和NVM多版本管理。同时覆盖全局npm工具配置、应用部署示例(如Express服务)、PM2持久化运行、阿里云安全组设置及外部访问验证等步骤,助你完成开发与生产环境的搭建。
|
11月前
|
运维 Serverless 测试技术
通义灵码 x 函数计算:构建高效开发流程,加速项目交付
通义灵码 x 函数计算:构建高效开发流程,加速项目交付
190 10
|
运维 Serverless 测试技术
通义灵码 x 函数计算:构建高效开发流程,加速项目交付
本方案基于通义大模型的通义灵码,提供代码生成、补全、优化及单元测试生成等能力,提升编码效率和质量。结合云效和函数计算 FC 进行代码管理、持续集成、部署发布,加速项目交付,为开发者提供智能编码、CI/CD、部署上线体验,加快产品迭代速度。
|
JavaScript Serverless Linux
函数计算产品使用问题之遇到Node.js环境下的请求日志没有正常输出时,该如何排查
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
前端开发 Serverless 应用服务中间件
Serverless痛点解决问题之将传统 LAMP/LNMP 项目直接 FaaS 化如何解决
Serverless痛点解决问题之将传统 LAMP/LNMP 项目直接 FaaS 化如何解决
236 0
|
机器学习/深度学习 Cloud Native Serverless
Serverless 架构问题之CNCF基金会托管的CloudEvents项目内容如何解决
Serverless 架构问题之CNCF基金会托管的CloudEvents项目内容如何解决
168 0

热门文章

最新文章