我今天开始使用Google App Engine,因此希望答案对有经验的人来说是显而易见的。在简单地遵循this method以使App Engine与Cloud SQL交互之后,我遇到了一个令人沮丧的问题: goapp部署成功,但是 goapp服务失败(使用云外壳)。
这是错误:
XXXX@cloudshell:~/src/XXXX/app-engine (XXXX)$ goapp serve app.yaml
INFO 2018-06-21 07:29:08,115 devappserver2.py:764] Skipping SDK update check.
INFO 2018-06-21 07:29:08,235 api_server.py:268] Starting API server at: http://0.0.0.0:60628
INFO 2018-06-21 07:29:08,305 dispatcher.py:199] Starting module "default" running at: http://0.0.0.0:8080
INFO 2018-06-21 07:29:08,306 admin_server.py:116] Starting admin server at: http://0.0.0.0:8000
ERROR 2018-06-21 07:29:12,254 go_runtime.py:181] Failed to build Go application: (Executed command: /google/go_appengine/goroot/bin/go-app-builder -app_base /home/XXX/app-engine -arch 6 -dynamic -goroot /google/go_appengine/goroot -gopath /home/XXX/gopath:/google/gopath -nobuild_files ^^$ -incremental_re
build -unsafe -binary_name _go_app -extra_imports appengine_internal/init -work_dir /tmp/tmpT1RTRMappengine-go-bin -gcflags -I,/google/go_appengine/goroot/pkg/linux_amd64_appengine -l
dflags -L,/google/go_appengine/goroot/pkg/linux_amd64_appengine hello.go)
/home/XXX/gopath/src/github.com/go-sql-driver/mysql/connection.go:12: can't find import: "context"
2018/06/21 07:29:09 Can't find package "context" in $GOPATH: cannot find package "context" in any of:
/google/go_appengine/goroot/src/context (from $GOROOT)
/home/XXX/gopath/src/context (from $GOPATH)
/google/gopath/src/context
2018/06/21 07:29:12 go-app-builder: build timing: 0×skip (3ms total), 9×compile (2.731s total), 0×link (0 total)
2018/06/21 07:29:12 go-app-builder: failed running compile: exit status 2
我怀疑使用的go版本是错误的。声明的版本是1.6.3,但据我了解,“上下文”需要1.7。这是相关的Cloud Shell输出:
XXXX@cloudshell:~ (XXX)$ goapp version
go version go1.6.3 (appengine-1.9.48) linux/amd64
XXXX@cloudshell:~ (XXX)$ go version
go version go1.10 linux/amd64
但是,尽管我已尽力而为,但我仍然找不到任何有关如何操纵“goapp” go版本的资源。
我的app.yaml包括:
runtime: go
api_version: go1.8
而 goapp get 会产生以下结果:
XXXX@cloudshell:~/src/XXX/app-engine (XXX)$ goapp get
package context: unrecognized import path "context" (import path does not begin with hostname)
go文件本身是上面链接中演示的精确副本。
最佳答案
如在comment on the question上确认的,解决方案使用 dev_appserver.py
而不是goapp serve
。goapp
是处理GAE任务的旧工具。现在建议使用dev_appserver.py
进行本地开发,并使用 gcloud app
命令处理云中的任务(例如gcloud app deploy
而不是goapp deploy
)。
请注意,不建议弃用goapp
,但是dev_appserver.py
在本地开发人员上提供了更大的灵活性,而gcloud app
使用了正确记录的,非常有用的App Engine Admin API(与旧版工具不同),在部署出现问题时,调试变得更加容易。
关于google-app-engine - Google App Engine应用程序“部署”有效,但“服务”失败,这是怎么回事?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/50963467/