本文将为您指导如何通过 Web Function,将您的本地 Django 快速部署到云端。
说明:本文档主要介绍控制台部署方案,您也可以通过命令行完成部署,详情请参见 通过命令行完成框架部署。
在使用腾讯云云函数服务之前,您需要 注册腾讯云账号 并完成 实名认证。
Django
选择 Django 框架模板并单击下一步。如下图所示:执行以下命令,确认您本地的环境已安装好 Django。
python -m pip install Django
在本地创建 Hello World
示例项目。
django-admin startproject helloworld && cd helloworld
目录结构如下:
$ tree
. manage.py 管理器
|--***
| |-- __init__.py 包
| |-- settings.py 设置文件
| |-- urls.py 路由
| `-- wsgi.py 部署
在本地执行 python manage.py runserver
命令运行启动文件。示例如下:
$ python manage.py runserver
July 27, 2021 - 11:52:20
Django version 3.2.5, using settings 'helloworld.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.
打开浏览器访问 http://127.0.0.1:8000
,即可在本地完成 Django 示例项目的访问。如下图所示:
接下来执行以下步骤,对本地已创建完成的项目进行简单修改,使其可以通过 Web Function 快速部署,对于 Django,具体修改步骤如下:
安装依赖包
由于 SCF 云上标准环境内未提供 Django 依赖库,此处您必须将依赖文件安装完成后,与项目代码一起打包上传。请先新建 requirements.txt
文件,文件内容如下:
Django==3.1.3
执行以下命令进行安装:
pip install -r requirements.txt -t .
说明:由于初始化的默认项目引用了
db.sqlite3
库,请同步安装该依赖,或将项目文件内setting.py
里DATABASES
字段部分配置注释。
新增 scf_bootstrap
启动文件
在 Web 函数内,限制了监听端口必须为9000,因此需要修改监听地址端口,在项目根目录下新建 scf_bootstrap
启动文件,在该文件添加如下内容(用于完成环境变量配置,指定服务启动命令等自定义操作,确保您的服务可以通过该文件正常启动):
#!/bin/bash
/var/lang/python3/bin/python3 manage.py runserver 9000
创建完成后,还需执行以下命令修改文件可执行权限,默认需要 777
或 755
权限才可以正常启动。示例如下:
chmod 777 scf_bootstrap
注意:
- 在 SCF 环境内,只有
/tmp
文件可读写,建议输出文件时选择/tmp
,其他目录会由于缺少权限而写入失败。- 如需在日志中输出环境变量,需在启动命令前加
-u
参数,例如python -u app.py
。
本地配置完成后,执行以下命令启动服务(如下命令为在 scf_bootstrap 目录下执行时示例),确保您的服务在本地可以正常启动。
注意:本地测试时注意将 python 路径改为本地路径。
./scf_bootstrap
登录 Serverless 控制台,单击左侧导航栏的函数服务。
在主界面上方选择期望创建函数的地域,并单击新建,进入函数创建流程。
选择从头开始新建函数,根据页面提示配置相关选项。
单击完成完成 Django 项目的部署。
部署完成后,即可在 SCF 控制台快速访问并测试您的 Web 服务,并且体验云函数多项特色功能,例如层绑定、日志管理等,享受 Serverless 架构带来的低成本、弹性扩缩容等优势,如下图所示:
本页内容是否解决了您的问题?