本文档指导您如何通过 Web 函数,快速迁移本地的 Laravel 服务上云。
说明:本文档主要介绍控制台部署方案,您也可以通过命令行完成部署,详情请参见 通过命令行完成框架部署。
在使用腾讯云云函数服务之前,您需要 注册腾讯云账号 并完成 实名认证。
WebFunc
,筛选所有 Web 函数模版,选择【Laravel 框架模版】并单击【下一步】。如下图所示:composer create-project --prefer-dist laravel/laravel blog
$ php artisan serve --host 0.0.0.0 --port 9000
Laravel development server started: <http: 0.0.0.0:9000="">
[Wed Jul 7 11:22:05 2021] 127.0.0.1:54350 [200]: /favicon.ico
http://0.0.0.0:9000
,即可在本地完成 Laravel 示例项目的访问。如下图所示:在该文件添加如下内容(用于配置环境变量和启动服务,此处仅为示例,具体操作请以您实际业务场景来调整):
接下来执行以下步骤,对已初始化的项目进行简单修改,使其可以通过 Web Function 快速部署,具体修改步骤如下:
新增 scf_bootstrap
启动文件
在项目根目录下新建 scf_bootstrap
启动文件,在该文件完成环境变量配置,指定服务启动命令等自定义操作,确保您的服务可以通过该文件正常启动。
注意:
scf_bootstrap
必须有755
或者777
的可执行权限。- 如需在日志中输出环境变量,需在启动命令前需要加
-u
参数,例如python -u app.py
。
修改文件读写路径
由于在 SCF 环境内,只有 /tmp
文件可读写,其他目录会由于缺少权限而写入失败,因此需要在 scf_bootstrap
里,以环境变量的方式注入,调整 Laravel 框架的输出目录:
#!/bin/bash
# 注入 SERVERLESS 标识
export SERVERLESS=1
# 修改模板编译缓存路径,云函数只有 /tmp 目录可读写
export VIEW_COMPILED_PATH=/tmp/storage/framework/views
# 修改 session 以内存方式(数组类型)存储
export SESSION_DRIVER=array
# 日志输出到 stderr
export LOG_CHANNEL=stderr
# 修改应用存储路径
export APP_STORAGE=/tmp/storage
# 初始化模板缓存目录
mkdir -p /tmp/storage/framework/views
修改监听地址与端口
在 Web 函数内,限制了监听端口必须为9000
,因此需要在 scf_bootstrap
中通过以下命令指定监听端口:
/var/lang/php7/bin/php artisan serve --host 0.0.0.0 --port 9000
完整 scf_bootstrap
内容如下:
部署上云
本地配置完成后,执行启动文件,确保您的服务可以本地正常启动。执行以下步骤部署 Laravel:
部署完成后,即可在 SCF 控制台快速访问并测试您的 Web 服务,并且体验云函数多项特色功能如层绑定、日志管理等,享受 Serverless 架构带来的低成本、弹性扩缩容等优势。
本页内容是否解决了您的问题?