无法使用使用外部库的运行时 1.12 部署 AppEngine Go 应用程序

Unable to deploy AppEngine Go app with runtime 1.12 that uses external libraries

我正在尝试将一个用 Go 编写的旧 Google App Engine(标准环境)项目迁移到运行时 1.12。自 2017 年底以来我就没有碰过它,从那以后似乎发生了很多变化。我已经能够解决一些问题,但是由于我有一些外部依赖项,所以我无法部署代码。

尝试部署时控制台输出的相关部分

d:\src\go\src\data-axe>go env GOPATH
d:\src\go

d:\src\go\src\data-axe>gcloud app deploy --no-promote
...
Error type: BuildError.
Error message: 2019/09/27 19:10:09 Your app is not on your GOPATH, this build may fail.
2019/09/27 19:10:10 Building from Go source in /tmp/staging/srv, with main package at ./...
2019/09/27 19:10:10 Building /tmp/staging/srv, saving to /tmp/staging/usr/local/bin/start
2019/09/27 19:10:11 Wrote build output to /builder/outputs/output
2019/09/27 19:10:11 Failed to build app: Your app is not on your GOPATH, please move it there and try again.
...
 err=exit status 1, out=srv/main.go:6:2: cannot find package "github.com/microcosm-cc/bluemonday" in any of:
...

如上面的代码片段所示,我的 GOPATH 设置为 d:\src\go,我的应用程序在 d:\src\go\src\data-axe 中,而我正在使用的 Bluemonday 在 d:\src\go\src\github.com\microcosm-cc\bluemonday 中,所以尽我所能所有这些知识都在我的 GOPATH 中。

specifying dependencies 的 App Engine 文档说

If your application is in a directory on your GOPATH, App Engine analyzes, copies, and uploads your imports from GOPATH. This approach supports vendor directories.

这里一定有我不明白的地方。我在 GOPATH 中使用了我的代码和库,但当我尝试部署时,App Engine 似乎没有提取和上传我的导入。

我的 main.go 中的导入使用的是绝对路径,正如文档所述:

package main

import (
    "fmt"
    "net/http"
    "github.com/microcosm-cc/bluemonday"
    "strings"
    "log"
    "os"
)

我做错了什么?


编辑

go env的完整输出:

d:\src\go\src\data-axe>go env
set GOARCH=amd64
set GOBIN=
set GOCACHE=C:\Users\niklas\AppData\Local\go-build
set GOEXE=.exe
set GOFLAGS=
set GOHOSTARCH=amd64
set GOHOSTOS=windows
set GOOS=windows
set GOPATH=d:\src\go
set GOPROXY=
set GORACE=
set GOROOT=c:\go
set GOTMPDIR=
set GOTOOLDIR=c:\go\pkg\tool\windows_amd64
set GCCGO=gccgo
set CC=gcc
set CXX=g++
set CGO_ENABLED=1
set GOMOD=
set CGO_CFLAGS=-g -O2
set CGO_CPPFLAGS=
set CGO_CXXFLAGS=-g -O2
set CGO_FFLAGS=-g -O2
set CGO_LDFLAGS=-g -O2
set PKG_CONFIG=pkg-config
set GOGCCFLAGS=-m64 -mthreads -fno-caret-diagnostics -Qunused-arguments -fmessage-length=0 -fdebug-prefix-map=C:\Users\niklas\AppData\Local\Temp\go-build168636674=/tmp/go-build -gno-record-gcc-switches

我设法用两种不同的方法解决了这个问题。

首先是将我的项目复制到我的 $GOPATH 之外,并启用 go 模块,如 this simple guide 中所述。当我这样做时,我能够成功部署我的应用程序,包括它的所有依赖项。

我也设法在没有go模块的情况下解决了这个问题。原来很久没有动过的不仅仅是我的项目。我的 Google Cloud SDK 也严重过时了。在我使用 gcloud components update 更新它之后,我能够正常部署我的应用程序而没有任何问题。