Serverless PHP Laravel Tencent Cloud

简介

腾讯云 Laravel Serverless Component, 支持 Restful API 服务的部署。

目录

0. 准备

初始化 Laravel 项目

在使用此组件之前,你需要先自己初始化一个 laravel 项目

  1. composer create-project --prefer-dist laravel/laravel serverless-laravel

注意:Laravel 使用 Coposer 管理依赖的,所以你需要先自行安装 Composer,请参考 官方安装文档

修改 Laravel 项目

由于云函数在执行时,只有 /tmp 可读写的,所以我们需要将 laravel 框架运行时的 storage 目录写到该目录下,为此需要修改 bootstrap/app.php 文件,在 $app = new Illuminate\Foundation\Application 后添加:

  1. $app->useStoragePath($_ENV['APP_STORAGE'] ?? $app->storagePath());

然后在跟目录下的 .env 文件中新增如下配置:

  1. # 视图文件编译路径
  2. VIEW_COMPILED_PATH=/tmp/storage/framework/views
  3. # 由于是无服务函数,所以没法存储 session 在硬盘上,如果不需要 sessions,可以使用 array
  4. # 如果需要你可以将 session 存储到 cookie 或者数据库中
  5. SESSION_DRIVER=array
  6. # 建议将错误日志输出到控制台,方便云端去查看
  7. LOG_CHANNEL=stderr
  8. # 应用的 storage 目录必须为 /tmp
  9. APP_STORAGE=/tmp

1. 安装

通过 npm 全局安装 serverless cli

  1. $ npm install -g serverless

2. 配置

在项目根目录,创建 serverless.yml 文件,在其中进行如下配置

  1. $ touch serverless.yml
  1. # serverless.yml
  2. MyComponent:
  3. component: '@serverless/tencent-laravel'
  4. inputs:
  5. region: ap-guangzhou
  6. functionName: laravel-function
  7. code: ./
  8. functionConf:
  9. timeout: 10
  10. memorySize: 128
  11. environment:
  12. variables:
  13. TEST: vale
  14. vpcConfig:
  15. subnetId: ''
  16. vpcId: ''
  17. apigatewayConf:
  18. protocol: https
  19. environment: release

3. 部署

如您的账号未 登陆注册 腾讯云,您可以直接通过 微信 扫描命令行中的二维码进行授权登陆和注册。

通过 sls 命令进行部署,并可以添加 —debug 参数查看部署过程中的信息

  1. $ sls --debug

注意: slsserverless 命令的简写。

4. 移除

通过以下命令移除部署的 API 网关

  1. $ sls remove --debug

账号配置(可选)

当前默认支持 CLI 扫描二维码登录,如您希望配置持久的环境变量/秘钥信息,也可以本地创建 .env 文件

.env 文件中配置腾讯云的 SecretId 和 SecretKey 信息并保存

如果没有腾讯云账号,可以在此 注册新账号

如果已有腾讯云账号,可以在 API 密钥管理 中获取 SecretIdSecretKey.

  1. # .env
  2. TENCENT_SECRET_ID=123
  3. TENCENT_SECRET_KEY=123