php小编新一为您介绍一种常见问题:“go aws-lambda 与 terraform 中的 exec 格式错误”。在使用aws-lambda和terraform创建函数时,可能会遇到Exec格式错误的问题。这可能是由于函数代码或terraform配置的错误导致的。本文将帮助您了解并解决此问题,让您能够顺利创建和运行aws-lambda函数。
问题内容
我实际上在使用 terraform 调用 golang lambda 时遇到了一个非常罕见的问题。所以基本上我使用 terraform 来部署我的所有资源,比如 lambda、带有 golang 的 api 网关。问题是,当我使用 terraform 将 golang lambda 二进制 .zip 文件部署到 lambda 时,在使用路由检查请求时,它会返回 exec 格式错误。 terraform 的所有代码都很好并且格式化,因为我测试了简单的 js lambda 函数,它工作得很好。我猜这是二进制架构的问题,但我使用与 aws 上使用的 lambda 相同的二进制架构。如果有人可以提供帮助,我也使用 Provide.al2 相同的问题,并出现 exec 格式错误。
一些调试信息
1-目录结构
- infra
-- helloGO
-- main.go
-- main // binary file
-- terraform
-- main.tf
-- hello.zip // with main binary file
登录后复制
2- terraform lambda 函数资源
resource "aws_lambda_function" "hello" {
function_name = "hello"
filename = "../hello.zip" // taking filename from root ./hello.zip
runtime = "go1.x" # nodejs16.x go1.x
handler = "main" # function.handler
role = aws_iam_role.hello_lambda_exec.arn
timeout = 3
}
登录后复制
3-构建命令
buildGO: cleanGO
GOOS=linux GOARCH=amd64 CGO_ENABLED=0 cd ./helloGo/ && go build -o ./ main.go
cd ./helloGo/ && chmod +x main
cd ./helloGo/ && zip ../hello.zip main
登录后复制
这将创建构建文件 main 并将其打包为 main.zip 以便 lambda terraform 文件使用。
(amd64 是 x86_64 的可执行文件)
我尝试提供了诸如使用 amd64 构建之类的解决方案,但不知道 lambda 调用 go 说二进制文件无法用此可执行文件执行
解决方法
您的环境设置是正确的,但您为错误的命令设置了它们。
GOOS=linux GOARCH=amd64 CGO_ENABLED=0 cd ./helloGo/ && go build -o ./ main.go
登录后复制
此行为 cd
命令设置 GOOS、GOARCH 和 CGO_ENABLED,而不是为 go build
设置。
试试这个:
cd ./helloGo/ && GOOS=linux GOARCH=amd64 CGO_ENABLED=0 go build -o ./ main.go
登录后复制
以上就是go aws-lambda 与 terraform 中的 exec 格式错误的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!