仅在部署时构建错误:无法使用appengine.AccessToken

时间:2017-05-26 05:49:00

标签: google-app-engine google-app-engine-go

我在编写一个简单的Go GAE(灵活)应用程序时,只要我引入cloud.google.com程序包以使用Google服务就无法部署。部署日志中的代码段:

...
golang.org/x/oauth2/google
# golang.org/x/oauth2/google
_gopath/src/golang.org/x/oauth2/google/appengine_hook.go:12: cannot use appengine.AccessToken (type func(appengine.Context, ...string) (string, time.Time, error)) as type func("golang.org/x/net/context".Context, ...string) (string, time.Time, error) in assignment
_gopath/src/golang.org/x/oauth2/google/appengine_hook.go:13: cannot use appengine.AppID (type func(appengine.Context) string) as type func("golang.org/x/net/context".Context) string in assignment
...

可以通过应用内的go install -v -tags appenginevm在本地重现,以进行部署。该应用程序在没有appenginevm标记的情况下构建并运行良好。

我刚刚关注了helloworld示例并对其进行了修改,并且找不到其他任何有此问题的人(一些Google搜索没有产生任何用处)。

任何人都知道如何解决这个/我缺少的东西?

提前致谢。完整的计划如下。

package main

import (
    "context"
    "fmt"
    "log"
    "net/http"
    "time"

    "cloud.google.com/go/storage"
)

var (
    client *storage.Client
)

func main() {
    ctx := context.Background()

    var err error
    client, err = storage.NewClient(ctx)
    if err != nil {
        log.Fatal(err)
        return
    }
    defer client.Close()

    http.HandleFunc("/_ah/health", healthCheckHandler)
    http.HandleFunc("/", indexHandler)
    log.Print("Listening on http://localhost:8080")
    log.Fatal(http.ListenAndServe(":8080", nil))
}

func httpError(w http.ResponseWriter, err error) {
    log.Println(err)
    http.Error(w, http.StatusText(http.StatusInternalServerError), http.StatusInternalServerError)
}

func healthCheckHandler(w http.ResponseWriter, r *http.Request) {
    fmt.Fprint(w, "OK")
}

func indexHandler(w http.ResponseWriter, r *http.Request) {
    start := time.Now()

    finish := time.Since(start)
    fmt.Fprintf(w, "Done %v %v", finish)
}

以下是app.yaml

env: flex
runtime: go

2 个答案:

答案 0 :(得分:0)

您可能应该使用

import "golang.org/x/net/context"

而不是

import "context"

答案 1 :(得分:0)

事实证明,我有一个旧版本的" google.golang.org/appengine"在本地打包,我不知道的是" gcloud app部署"命令似乎上传所有这些依赖项,而不是远程解析依赖项。

所以这个库的旧本地副本打破了远程编译过程。

我通过运行" go get -u google.golang.org/appengine"纯粹是出于好奇而想出来的。让它失败:

package google.golang.org/appengine: google.golang.org/appengine is a custom import path
for https://github.com/golang/appengine, but
$GOPATH/src/google.golang.org/appengine is checked out from
https://github.com/golang/appengine.git

所以我对此进行了修改并得到了一份新的副本,现在一切正常。

TL;如果出现远程编译错误,请确保您的本地软件包都是最新的。