与其说 Serverless 架构是一个新的概念,不如说它是一种全新的思路,一种新的编程范式。

但是原生的 Serverless 开发框架却非常少。以 Web 框架为例,目前主流的 Web 框架“均不支持 Serverless 模式部署”,因此我们一方面要尝试接触 Serverless,一方面又没办法完全放弃传统框架,所以如何将传统框架更简单、更快速、更科学地部署到 Serverless 架构是一个值得探讨的问题。

请求集成方案

请求集成方案实际上就是把真实的 API 网关请求直接透传给 FaaS 平台,而不在中途增加任何转换逻辑。以阿里云函数计算的 HTTP 函数为例,当想要把传统框架(例如 Django、Flask、Express、Next.js 等)部署到阿里云函数计算平台,并且体验Serverless架构带来的按量付费、弹性伸缩等红利时,得益于阿里云函数计算的 HTTP 函数和 HTTP 触发器,使用者不仅可以快速、简单地将框架部署到阿里云函数计算平台,还可以获得和传统开发一样的体验。

例如以 Python 的 Bottle 框架开发一个 Bottle 项目:

# index.py
import bottle@bottle.route('/hello/<name>')
def index(name):
return "Hello world"if __name__ == '__main__':
bottle.run(host='localhost', port=8080, debug=True)

之后,可以直接在本地进行调试。当想要把该项目部署到阿里云函数计算平台时,只需要增加一个 default_app 的对象即可:

app = bottle.default_app()

整个项目的代码如下所示:

# index.py
import bottle@bottle.route('/hello/<name>')
def index(name): return "Hello world"
app = bottle.default_app()
if __name__ == '__main__':bottle.run(host='localhost', port=8080, debug=True)

若在阿里云函数计算平台创建函数,将入口函数设置为 index.app 即可。除了 Bottle 框架之外,其他 Web 框架的操作方法是类似的,再以 Flask 为例:

# index.py
from flask import Flask
app = Flask(__name__)@app.route('/')
def hello_world(): return 'Hello, World!'if __name__ == '__main__': app.run( host="0.0.0.0",port=int("8001")
)

在创建函数的时候设置入口函数为 index.app,就可以保证该 Flask 项目运行在函数计算平台上。

当然,除了使用已有的语言化 Runtime(指具体语言的运行时,例如 Python3 运行时、Node. js12 运行时),我们还可以考虑使用 Custom Runtime 和 Custom Container 来实现,例如,一个 Web 项目完成之后,可以编写一个 Bootstrap 文件(在 Bootstrap 文件中写一些启动命令)。

例如要启动一个 Express 项目,把 Express 项目准备完成之后,可以直接创建 Bootstrap 文件,并将启动命令配置到该文件中:

#!/usr/bin/env bash
export PORT=9000
npm run star

阿里云函数计算还提供了更简单的 Web 框架迁移方案。如图所示是阿里云函数计算页面传统 Web 框架迁移功能示例。

阿里云函数计算页面传统 Web 框架迁移功能

选择对应的环境之后,只需要上传代码,做好简单的配置,即可让传统的 Web 框架迁移至阿里云函数计算平台。

如果通过开发者工具进行部署,以 Serverless Devs 为例,首先创建 index.py:

# -*- coding: utf-8 -*-
from bottle import route, run@route('/')
def hello(): return "Hello World!"run(host='0.0.0.0', debug=False, port=9000)
然后编写资源和行为描述文件:
edition: 1.0.0
name: framework                                                       #项目名称
access: "default"                                                     #密钥别名services:framework:                                                        #业务名称/模块名称component: fc                                                 #组件名称actions:pre-deploy: #在部署之前运行- run: pip3 install -r requirements.txt -t .          #要运行的命令行path: ./code                                       #命令行运行的路径props:                                                        #组件的属性值region: cn-beijingservice:name: web-frameworkdescription: 'Serverless Devs Web Framework Service'function:name: bottledescription: 'Serverless Devs Web Framework Bottle Function'codeUri: './code'runtime: python3 handler: index.app timeout: 60triggers:- name: httpTriggertype: httpconfig:authType: anonymousmethods:- GETcustomDomains:- domainName: autoprotocol: HTTProuteConfigs:- path: '/*'
同时,提供对应的Bootstrap文件,即启动文件:
#!/bin/bash
python3 index.py

完成之后,执行 deploy 指令进行部署:

s deploy

部署结果如图所示。

Serverless Devs 部署 Bottle 框架过程

根据返回的网址,可以看到部署结果预览,如下图所示。

Serverless Devs 部署结果预览

通过 Serverless Devs 开发者工具,我们不仅可以简单地进行传统 Web 框架的部署,还可以快速在 Serverless 架构下进行传统 Web 框架的初始化。以 Express 项目为例,只需要通过 Serverless Devs 开发者工具执行如下代码即可进行 Express.js 项目的初始化。

s init start-express

初始化的过程如图所示。此时,只需要进入该项目执行如下代码即可快速进行项目的部署。

s deploy

通过 Serverless Devs 初始化 Express 项目

部署结果如图所示。

打开系统分配的地址,可以看到通过 Serverless Devs 开发者工具初始化的 Express 项目,效果展示如下图所示。

Express 项目完成效果展示

当然,目前 Serverless Devs 开发者工具不仅支持 Express 项目的快速初始化(见表),还支持包括 Django、Flask、SpringBoot 等数十个传统框架的快速创建与部署。

Serverless Devs 支持快速创建和部署的传统框架

综上所述,通过阿里云函数计算进行传统 Web 框架的部署和迁移是很方便的,并且得益于 HTTP 函数与 HTTP 触发器,整个过程侵入性非常低。当然,将传统 Web 框架部署到阿里云上的可选方案也比较多。

  • 编程语言化的 Runtime:只需要写好函数入口即可。
  • Custom Runtime:只需要写好 Bootstrap 即可。
  • Custom Container:直接按照规范上传镜像文件即可。

部署途径也是多种多样的,具体如下。

  • 直接在控制台创建函数。
  • 在应用中心处创建 Web 应用。
  • 利用开发者工具。

其他方案

相对于阿里云的 HTTP 函数以及 HTTP 触发器,其他 FaaS 平台则需要借助 API 网关以及一个转换层来实现传统 Web 框架到 FaaS 平台的部署。

如图所示,以 Python Web 框架为例,在通常情况下,使用 Flask 等框架时实际上要通过 Web Server 才能进入下一个环节,而云函数是一个函数,本不需要启动 Web Server,所以可以直接调用 wsgi_app 方法。

传统 WSGI Web Server 工作原理示例

这里的 environ 就是对 event/context 等处理后的对象,也就是所说的转换层要做的工作;start_response 可以认为是一种特殊的数据结构,例如 response 结构形态等。

当然,转换工作在某些情况下还是比较麻烦的,所以很多时候我们可以借助常见的开发者工具进行传统 Web 框架的部署,例如借助开源的开发者工具 Serverless Devs、Serverless Framework 等。

作者介绍

刘宇,阿里云 Serverless 产品经理
田初东,蚂蚁集团算法工程师
卢萌凯,阿里云 Serverless 高级解决方案架构师
王仁达,阿里云 Serverless 工具链技术负责人

点击此处 ,直达阿里云函数计算 FC!

传统 Web 框架部署与迁移相关推荐

  1. 如何将传统 Web 框架部署到 Serverless

    背景 因为 Serverless 的"无服务器架构"应用相比于传统应用有很多优点,比如:无需关心服务器.免运维.弹性伸缩.按需付费.开发可以更加关注业务逻辑等等,所以现在 Serv ...

  2. 从使用传统Web框架到切换到Spring Boot后的总结

    1.前言 其实我接触 Spring Boot 的时间并不长,所以还算一个初学者,这篇文章也算是我对 Spring Boot 学习以及使用过程中的复盘,如果文章出现描述错误或表达不清晰的地方,欢迎大家在 ...

  3. django 热启动_传统的Web框架如何部署在Serverless架构上(以Flask为例)

    前言 Serverless架构是一个新的概念,也可以说是一个新的架构或者技术,但是无论他有多新,都不能一下子完成现有都开发习惯到Serverless架构的过渡,让现有的工程师放弃现有的Express. ...

  4. 揭秘12306技术改造(三):传统框架云化迁移到内存数据平台

    注:本文首发于CSDN,转载请标明出处. [编者按]在年前的「技术揭秘12306改造」专题中,负责12306改造的技术架构师刘云程从技术的角度.用科学论证的方式说明 12306是如何实现高流量高并发的 ...

  5. 在tomcat上部署项目需要打成jar_Spring Boot Web 项目教程,SpringBoot与传统Web 优缺对比...

    1.引子 大家好,在接下里的一段时间里,我会给大家详细的介绍SpringBoot的基本使用,相信学完这门课程以后,你会对SpringBoot有一个清晰的认识,并且能够运用这门比较新颖的技术开发一些小程 ...

  6. [转载] 新兵训练营系列课程——平台服务部署及Web框架

    原文: http://weibo.com/p/1001643875679132642345 大纲 微博平台主要负责微博基础功能.接下来将会介绍 平台的作用,以及服务提供的形式 平台Web服务的部署 平 ...

  7. 使用 python web 框架 进行高并发模型上线部署 的架构 思路探索

    文章大纲 web 框架性能测试 基准 sanic lstm yolo postman post 图片 sanic 服务处理 flask + gevent + gunicorn lstm yolo gr ...

  8. Web函数请求多并发上线,Web服务部署更快更省

    Web函数(Web Function)是云函数的一种函数类型,区别于事件函数(Event Function),Web函数通过支持原生的HTTP/WebSocket协议,兼容任意一种原生Web框架编写的 ...

  9. Python Web框架比较,选择对的框架让开发更便捷

    Python程序员有很多很好的选择来创建Web应用程序和API:Django,Weppy,Bottle和Flask引领潮流. 如果正在开发一个Web应用程序并且已经选择使用Python作为构建它的语言 ...

最新文章

  1. HDU-5532(LIS-nlogn)
  2. Spring Boot 进行优雅的字段校验,写得太好了!
  3. 名词解释_名词解释的答题技巧
  4. 对人工智能的应用、发展及其影响的思考
  5. ehcache 程序_将Ehcache添加到Openxava应用程序
  6. 自定义sql_【PL/SQL 自定义函数】 常用场景
  7. php连接mysql遇到的问题: (HY000/1130) 和 [caching_sha2_password]
  8. python中‘/’和‘//’区别
  9. [angularjs]初学小记1
  10. RSA加密算法【手把手解释】
  11. cs6给画笔分组_画笔工具,PS cs6笔刷入门介绍
  12. 直流电压前馈控制数字逆变电源设计与实现
  13. 隧道凿岩机器人传感器_隧道凿岩机器人钻臂液压控制系统的设计(精品)☆
  14. 等额本金等额本息推导
  15. android文件恢复功能,终于找到了安卓手机删除的文件的恢复方法值得一看
  16. Java类属性字段校验(validation的使用)
  17. python正弦函数_Python之正弦曲线实现方法分析
  18. IDEA 使用 hibernate
  19. 自定义流式布局的代码实现
  20. ZooKeeper session has been expired

热门文章

  1. 频偏(ppm)计算公式
  2. 文件夹无法删除提示找不到该项目
  3. 信息工程学院技能大赛 计算机程序设计(Java)大赛试题
  4. H2数据库安装部署及简单使用
  5. 潍坊学院计算机工程学院天一楼地址,我院志愿汇APP系统培训会
  6. xp系统关闭文件和打印共享服务器,XP打印共享四大问题及解决方法
  7. 域用户如何批量修改服务器时间,如何批量修改word中的域
  8. 云计算战役升温:微软IBM掷千金道不同
  9. proteus仿真micropython_用Python让单片机“行动”起来——MicroPython实战入门篇
  10. 如果host1要传送文件到服务器,南京晓庄学院思科网络网上作业