我正试图开始学习serverless lambda,所以我创建了一个简单的lambda,并将其与serverless一起部署,这工作。
然而,当我想测试lambda的端点时,我得到了一个 502
回。当我查看日志时,它告诉我,它找不到模块 handler
这没有任何意义...
这里是日志。
{
"errorType": "Runtime.ImportModuleError",
"errorMessage": "Error: Cannot find module 'handler'\nRequire stack:\n-
/var/runtime/UserFunction.js\n- /var/runtime/index.js",
"trace": [
"Runtime.ImportModuleError: Error: Cannot find module 'handler'",
"Require stack:",
"- /var/runtime/UserFunction.js",
"- /var/runtime/index.js",
" at _loadUserApp (/var/runtime/UserFunction.js:100:13)",
" at Object.module.exports.load (/var/runtime/UserFunction.js:140:17)",
" at Object.<anonymous> (/var/runtime/index.js:43:30)",
" at Module._compile (internal/modules/cjs/loader.js:1158:30)",
" at Object.Module._extensions..js (internal/modules/cjs/loader.js:1178:10)",
" at Module.load (internal/modules/cjs/loader.js:1002:32)",
" at Function.Module._load (internal/modules/cjs/loader.js:901:14)",
" at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:74:12)",
" at internal/main/run_main_module.js:18:47"
]
}
这通常意味着它找不到作为执行起点的方法。
例如,在你的serverless.yml中,你可以有这样的内容。
functions:
getUsers:
handler: userFile.handler
这意味着,它需要有一个。userFile
在serverless.yml的同一个文件夹中,导出方法处理程序。
module.exports.hello = async event => {
return {
statusCode: 200,
body: JSON.stringify(
{
message: 'Go Serverless v1.0! Your function executed successfully!',
input: event,
},
null,
2
),
};
};
注意,它不需要命名为handler函数,只需要在serverless.yml中定义相同的名称即可。