应用中心框架部署方案已经全新升级,您可以通过 SCF Web Function
,快速部署您的 Django 业务上云。
注意:应用控制台部署与函数直接部署有什么区别?
通过应用部署或函数部署,均可以基于 Web 函数,快速部署常见 Web 框架。
本篇文档为您介绍应用控制台的部署方案,您也可以通过命令行完成部署,具体操作请参考 产品文档。
执行以下命令,确认您本地的环境已安装好 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,具体修改步骤如下:
1. 安装依赖包
由于 SCF 云上标准环境内未提供 Django 依赖库,此处您必须将依赖文件安装完成后,与项目代码一起打包上传。请先新建 requirements.txt
文件,文件内容如下:
Django==3.1.3
执行以下命令进行安装:
pip install -r requirements.txt -t .
注意:由于初始化的默认项目引用了
db.sqlite3
库,请同步安装该依赖,或将项目文件内setting.py
里DATABASES
字段部分配置注释掉。
2. (可选)配置 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
3. 控制台上传
登录 Serverless 应用控制台,选择Web 应用>Django 框架,上传方式可以选择本地上传或代码仓库拉取
您可以在控制台完成启动文件 scf_bootstrap
内容配置,配置完成后,控制台将为您自动生成 启动文件,和项目代码一起打包部署。
注意:启动文件以项目内文件为准,如果您的项目里已经包含
scf_bootstrap
文件,将不会覆盖该内容。
配置完成后,单击完成,部署您的 Django 项目。
您可在“高级配置”里进行更多应用管理操作,如创建层、绑定自定义域名、配置环境变量等。
本页内容是否解决了您的问题?