我正在尝试在netflix函数上部署一个非常简单的Go函数。
我遵循了指南,但是指南并没有很好地解释Go的设置。
我使用了目前推荐的方法,基本上是go init
,根据需要更改我的go文件,然后是go mod tidy
。这创建了合适的go。装好就走。
我还在website/index.html
上创建了一个非常简单的网站,所以我可以测试该网站是否可以"运行"。这个函数。这意味着我配置了"基本目录"。对于Netlify构建为website/
(这是我通常如何与我在Netlify上的其他网站一起做,这工作得很好)。
编辑:我尝试将所有内容移动到根目录,而不是使用website/
作为基本目录,但问题仍然相同。
然后我移动了所有Go文件,包括Go。装好就走。sum,到website/netlify/functions/analytics/
(所以我的函数将被称为analytics
,在指南中解释过),并push。
website/netlify/functions/analytics
目录:
go.mod go.sum handlers.go main.go main_test.go
然而,Netlify构建失败了:
5:33:45 PM: ❯ Current directory
5:33:45 PM: /opt/build/repo/website
5:33:45 PM:
5:33:45 PM: ❯ Config file
5:33:45 PM: No config file was defined: using default values.
5:33:45 PM:
5:33:45 PM: ❯ Context
5:33:45 PM: production
5:33:45 PM:
5:33:45 PM: ────────────────────────────────────────────────────────────────
5:33:45 PM: 1. Functions bundling
5:33:45 PM: ────────────────────────────────────────────────────────────────
5:33:45 PM:
5:33:45 PM: Packaging Functions from netlify/functions directory:
5:33:45 PM: - analytics/main.go
5:33:45 PM:
5:33:45 PM: Could not compile Go function analytics:
5:33:45 PM:
5:33:45 PM: ────────────────────────────────────────────────────────────────
5:33:45 PM: Bundling of Function "analytics" failed
5:33:45 PM: ────────────────────────────────────────────────────────────────
5:33:45 PM:
5:33:45 PM: Error message
5:33:45 PM: Command failed with exit code 1: go build -o /tmp/zisi-629b7b4be8f858000804bf6c/analytics -ldflags -s -w (https://ntl.fyi/exit-code-1)
5:33:45 PM: go: github.com/aws/aws-lambda-go@v1.32.0 requires
5:33:45 PM: github.com/stretchr/testify@v1.6.1: missing go.sum entry; to add it:
5:33:45 PM: go mod download github.com/stretchr/testify
5:33:45 PM:
5:33:45 PM: Error location
5:33:45 PM: While bundling Function "analytics"
5:33:45 PM:
5:33:45 PM: Resolved config
5:33:45 PM: build:
5:33:45 PM: base: /opt/build/repo/website
5:33:45 PM: publish: /opt/build/repo/website
5:33:45 PM: publishOrigin: ui
5:33:45 PM: functionsDirectory: /opt/build/repo/website/netlify/functions
这个错误显示netflix可以正确地找到go文件,但由于某种原因它似乎忽略了go。Sum,因为该文件包含正确的校验和:
github.com/aws/aws-lambda-go v1.32.0 h1:i8MflawW1hoyYp85GMH7LhvAs4cqzL7LOS6fSv8l2KM=
github.com/aws/aws-lambda-go v1.32.0/go.mod h1:IF5Q7wj4VyZyUFnZ54IQqeWtctHQ9tz+KhcbDenr220=
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
github.com/stretchr/testify v1.6.1 h1:hDPOHmpOpP40lSULcqw7IrRb/u7w6RpDC9399XyoNd0=
gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776 h1:tQIYjPdBoyREyB9XMu+nnTclpTYkz2zFM+lzLJFO4gQ=
可能有什么问题,我该如何解决?
截至撰写本文时,netflix正在使用较旧版本的Go 1.16.5来构建。
这意味着我该走了。mod文件甚至不应该被旧的Go编译器接受!无论如何,我在本地安装了那个版本的Go来尝试一下…
下面是如何安装一个特定版本的Go(假设你在本地安装了Go 1.18):
$ go install golang.org/dl/go1.16.5@latest
$ go1.16.5 download
现在你可以运行go1.16.5
来尝试旧的编译器。
我写了一个Makefile,让我使用任何版本的Go来构建…如下所示:
## To use a different version of Go, run like this:
## make all GO=go1.16.5
GO:=go
.PHONY: test
test:
cd analytics && $(GO) test .
../netlify/functions/analytics: test
cd analytics && $(GO) build -o ../netlify/functions/analytics .
all: ../netlify/functions/analytics
下面是使用go1.16.5的结果:
▶ make all GO=go1.16.5
cd analytics && go1.16.5 test .
go: github.com/aws/aws-lambda-go@v1.32.0 requires
github.com/stretchr/testify@v1.6.1: missing go.sum entry; to add it:
go mod download github.com/stretchr/testify
make: *** [test] Error 1
我在netflix上也看到了同样的错误!很好,这就是问题所在。
现在,为了解决这个问题,我不得不删除go.mod
和go.sum
,并使用旧的Go版本重新生成它们,我通过编写这个Make任务来完成:
.PHONY: setup
setup:
cd analytics && rm go.mod go.sum && $(GO) mod init renato/analytics && $(GO) mod tidy
现在,使用旧的Go在本地成功构建:
▶ make setup all GO=go1.16.5
cd analytics && rm go.mod go.sum && go1.16.5 mod init renato/analytics && go1.16.5 mod tidy
go: creating new go.mod: module renato/analytics
go: to add module requirements and sums:
go mod tidy
go: finding module for package github.com/aws/aws-lambda-go/lambda
go: finding module for package github.com/aws/aws-lambda-go/events
go: found github.com/aws/aws-lambda-go/events in github.com/aws/aws-lambda-go v1.32.0
go: found github.com/aws/aws-lambda-go/lambda in github.com/aws/aws-lambda-go v1.32.0
cd analytics && go1.16.5 test .
ok renato/analytics 0.166s
cd analytics && go1.16.5 build -o ../netlify/functions/analytics .
我决定在此之后提交Go文件,让netflix看到这些文件的正确版本,但我也"定制了构建"。(如文档中解释的那样)只需告诉netflix运行我的构建命令make all
(不是make setup
,因为如果提交go,则不需要它)。装好就走。在netflix UI上(在站点设置中)。这可能不是必需的,但我想确定正在执行正确的命令。
最后,该构建也适用于netflix !!
7:36:59 PM: ────────────────────────────────────────────────────────────────
7:36:59 PM: 1. Build command from Netlify app
7:36:59 PM: ────────────────────────────────────────────────────────────────
7:36:59 PM:
7:36:59 PM: $ make all
7:36:59 PM: cd analytics && go test .
7:37:00 PM: go: downloading github.com/aws/aws-lambda-go v1.32.0
7:37:08 PM: ok renato/analytics 0.017s
7:37:08 PM: cd analytics && go build -o ../netlify/functions/analytics .
7:37:09 PM:
7:37:09 PM: (build.command completed in 9.2s)
7:37:09 PM:
7:37:09 PM: ────────────────────────────────────────────────────────────────
7:37:09 PM: 2. Functions bundling
7:37:09 PM: ────────────────────────────────────────────────────────────────
7:37:09 PM:
7:37:09 PM: Packaging Functions from netlify/functions directory:
7:37:09 PM: - analytics
7:37:09 PM:
7:37:09 PM:
7:37:09 PM: (Functions bundling completed in 101ms)
所以,问题是Go版本netflix已经过时了,不幸的是Go一直在乱搞Go mod格式,这导致了这样的兼容性问题…你可能需要准确版本的Go编译器来让一个给定的项目正确编译,就像在这个例子中一样。