本文介绍使用Serverless Devs工具过程中可能遇到的问题,并提供对应的解决方案。
如何配置s.yaml文件?
关于YAML规范的详细信息,请参见YAML规范。
使用Serverless Devs偶然出现异常,但未提示错误信息怎么办?
您可以按照以下步骤排查问题。
执行命令
npm install @serverless-devs/s3 -g
升级工具。执行命令
s clean --all
删除所有组件及冗余文件。执行
s -v
查看工具版本。如果执行命令后无任何响应,可能是本地Node.js环境异常,需重新安装Node.js 14或以上的版本。
如果问题还未解决,请加入钉钉用户群(钉钉群号64970014484),并提供日志文件和s.yaml
文件,联系函数计算开发工程师帮您解决。
关于日志文件的获取方式,请参见下图。
新项目部署完成后,在控制台找不到函数如何处理?
如果s deploy
命令完成后,在控制台找不到函数,您可以尝试以下方法。
通过前缀匹配搜索,查找您部署的函数。有些项目会创建多个函数,您可以编辑
s.yaml
,使项目内所有functionName
的前缀相同,以便查找。单击按钮,刷新函数列表。
如果您想使用应用中心管理Serverless Devs项目,您可以在s init
后,将项目提交至在线仓库,然后在应用中心导入应用,具体操作,请参见管理应用。导入应用后,在提交更改至仓库后,流水线将自动部署项目,您不再需要使用s deploy
命令部署项目。
部署项目时,本地配置和线上配置有冲突,如何处理?
当本地配置(即
s.yaml
中的配置)和线上配置有冲突时,Serverless Devs将询问您是否使用本地配置部署,您可以选择使用本地配置,或保留线上配置。如果您希望默认使用本地配置,可以使用
-y
选项,即s deploy -y
。
Serverless Devs工具支持多Region部署吗?
支持。具体操作,请参见以下示例。
Shell脚本
```bash
#!/bin/bash
regions=("cn-hangzhou" "ap-southeast-1")
for r in ${regions[@]}
do
export REGION=$r
s deploy -y
done
```
s.yaml示例
```yaml
edition: 3.0.0
name: hello-world-app
access: "default"
resources:
hello_world:
component: fc3
props:
region: ${env('REGION')}
functionName: "start-nodejs-im1g"
description: 'hello world by serverless devs'
runtime: "nodejs14"
code: ./code
handler: index.handler
memorySize: 128
timeout: 30
```
如何本地调试函数?
如果您的运行时不是自定义运行时或自定义镜像,而是函数计算内置语言,例如Node.js、Python等,推荐使用Serverless Devs工具的本地调用方式进行调试。具体操作,请参见Local命令。
如果您的运行时是自定义运行时或自定义镜像,可以按照正常的开发习惯启动一个Server代码调试流程。
说明针对自定义运行时,
s local invoke
命令能正常发起函数本地执行,但不支持断点调试。
怎样使用.fcignore文件?
您可以在代码指定目录下配置一个.fcignore
文件,.fcignore
文件用于定义忽略相关文件或者将文件夹打包到函数代码的ZIP包。更多信息,请参见.fcignore使用方法。
s.yaml文件中定义了多个函数时如何指定部署和调用某个函数?
s.yaml文件中,可能存在一个服务对应多个函数的情况,如果只想部署或调用其中某一个函数,可以在执行命令s deploy
、s info
或s local invoke
时,指定资源名称。例如,s.yaml文件示例如下,包含多个函数,部署函数时可以执行s helloworld1 deploy
只部署helloworld1
函数。
```yaml
edition: 3.0.0
name: hello-world-app
access: "default"
resources:
hello_world1:
component: fc3
props:
region: cn-huhehaote
functionName: "hello_world1"
description: 'hello world1 by serverless devs'
runtime: "nodejs14"
code: ./code
handler: index.handler
hello_world2:
component: fc3
props:
region: cn-huhehaote
functionName: "hello_world2"
description: 'hello world2 by serverless devs'
runtime: "nodejs14"
code: ./code
handler: index.handler
```
如何基于Podman,使用Serverless Devs工具进行构建与本地调试?
使用Serverless Devs工具执行构建或本地调试函数时,如果基于Podman工具,会提示报错Failed to start docker, xxx
,此时,您可以创建一个Docker目录软链接指向Podman的目录,然后再执行构建或本地调试。创建软链接的具体操作如下所示。
查询Podman可执行文件路径。
which podman
本文示例中Podman可执行文件路径为
/usr/bin/podman
。设置软链接。
ln -s /usr/bin/podman /usr/bin/docker
查询软链接是否已生效。
ls -lh /usr/bin/docker
预期输出如下:
lrwxrwxrwx 1 root root 15 Jan 5 09:30 /usr/bin/docker -> /usr/bin/podman