迁移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


相关实践学习
【玩转ComfyUI】基于函数计算一键部署AI生图平台ComfyUI
本次实验将带大家通过使用阿里云产品函数计算FC,快速使用ComfyUI实现更高质量的图像生成。
从 0 入门函数计算
在函数计算的架构中,开发者只需要编写业务代码,并监控业务运行情况就可以了。这将开发者从繁重的运维工作中解放出来,将精力投入到更有意义的开发任务上。
相关文章
|
8月前
|
机器学习/深度学习 人工智能 Serverless
吉利汽车携手阿里云函数计算,打造新一代 AI 座舱推理引擎
当前吉利汽车研究院人工智能团队承担了吉利汽车座舱 AI 智能化的方案建设,在和阿里云的合作中,基于星睿智算中心 2.0 的 23.5EFLOPS 强大算力,构建 AI 混合云架构,面向百万级用户的实时推理计算引入阿里云函数计算的 Serverless GPU 算力集群,共同为智能座舱的交互和娱乐功能提供大模型推理业务服务,涵盖的场景如针对模糊指令的复杂意图解析、文生图、情感 TTS 等。
|
10月前
|
人工智能 运维 Cloud Native
阿里云Serverless计算产品入选Gartner®报告「领导者」象限!
近日,Gartner® 发布了 2025 年度全球《云原生应用平台魔力象限》报告,阿里云凭借 Serverless 应用引擎 SAE(以下简称 SAE)和函数计算 FC,成为亚太地区唯一入选「领导者象限」的科技公司。
856 18
|
10月前
|
运维 NoSQL Serverless
|
9月前
|
消息中间件 运维 监控
爆款游戏背后:尚娱如何借助阿里云 Kafka Serverless 轻松驾驭“潮汐流量”?
阿里云 Kafka 不仅为尚娱提供了高可靠、低延迟的消息通道,更通过 Serverless 弹性架构实现了资源利用率和成本效益的双重优化,助力尚娱在快速迭代的游戏市场中实现敏捷运营、稳定交付与可持续增长。
386 77
|
9月前
|
消息中间件 存储 运维
嘉银科技基于阿里云 Kafka Serverless 提升业务弹性能力,节省成本超过 20%
云消息队列 Kafka 版 Serverless 系列凭借其秒级弹性扩展、按需付费、轻运维的优势,助力嘉银科技业务系统实现灵活扩缩容,在业务效率和成本优化上持续取得突破,保证服务的敏捷性和稳定性,并节省超过 20% 的成本。
798 69
|
9月前
|
人工智能 机器人 Serverless
安诺机器人 X 阿里云函数计算 AI 咖啡印花解决方案
当云计算遇见具身智能,AI咖啡开启零售新体验。用户通过手机生成个性化图像,云端AI快速渲染,机器人精准复刻于咖啡奶泡之上,90秒内完成一杯可饮用的艺术品。该方案融合阿里云FunctionAI生图能力与安诺机器人高精度执行系统,实现AIGC创意到实体呈现的闭环,为线下零售提供低成本、高互动、易部署的智能化升级路径,已在商场、机场、展馆等场景落地应用。
安诺机器人 X 阿里云函数计算 AI 咖啡印花解决方案
|
人工智能 运维 安全
阿里云函数计算 AgentRun 全新发布,构筑智能体时代的基础设施
阿里云推出以函数计算为核心的AgentRun平台,通过创新体系解决开发、部署、运维难题,提供全面支持,已在多个真实业务场景验证,是AI原生时代重要基础设施。
|
9月前
|
人工智能 运维 安全
阿里云函数计算 AgentRun 全新发布,构筑智能体时代的基础设施
云原生应用平台 Serverless 计算负责人杨皓然在云栖大会发表主题演讲“Serverless Agent 基础设施:助力大规模 Agent 部署与运维”。本议题深入介绍了阿里云以函数计算为核心打造的 Agent 基础设施——AgentRun,阐述其如何通过创新的运行时、模型服务、网关及可观测体系,为企业构筑坚实、高效、安全的 Agent 时代基石。
|
10月前
|
运维 NoSQL Serverless
《第四纪元》玩得轻松,构建也轻松 | 阿里云云原生 API 网关、函数计算助力 IGame 快速构建轻休闲游戏
在轻休闲游戏流量波动大、生命周期短的背景下,传统架构难以应对成本与扩展挑战。本文介绍了基于阿里云函数计算 FC 和 Redis 构建的新一代服务器架构,实现弹性伸缩、成本优化与高效运维,助力轻休闲游戏快速迭代与稳定运营,提升开发效率并降低运维复杂度。
《第四纪元》玩得轻松,构建也轻松 | 阿里云云原生 API 网关、函数计算助力 IGame 快速构建轻休闲游戏
|
DataWorks 数据挖掘 Serverless
阿里云EMR Serverless StarRocks 内容合集
阿里云 EMR StarRocks 提供存算分离架构,支持实时湖仓分析,适用于多种 OLAP 场景。结合 Paimon 与 Flink,助力企业高效处理海量数据,广泛应用于游戏、教育、生活服务等领域,显著提升数据分析效率与业务响应速度。
588 0