Как заставить golang gin работать с движком приложения Google? - PullRequest
0 голосов
/ 28 сентября 2018

Моя GOPATH равна $HOME/go, я поместил исходный код моего проекта в $HOME/go/src/myproj

и есть два файла:

app.yaml:

application: hello
version: 1
runtime: go
api_version: go1

handlers:
- url: /.*
  script: _go_app

и hello.go

package hello

import (
        "net/http"
        "github.com/gin-gonic/gin"
)

func ping(c *gin.Context) {
        c.JSON(200, gin.H{
                "message": "pong",
        })
}

func init() {
        r := gin.Default()

        api := r.Group("/api")
        {
          api.GET("/ping", ping)
        }

        http.Handle("/", r)
}

Затем я запускаю dev_appserver.py .

Работает,

curl http://127.0.0.1:8080/api/ping
{"message":"pong"}

Затем я решил разделить hello.go следующим образом:

new hello.go

package hello

import (
        "net/http"
        "github.com/gin-gonic/gin"
        "./api"
        // "myproj/api" // does not work too
)

func init() {
        r := gin.Default()

        api.addRoute()

        http.Handle("/", r)
}

и папка api, а также api/api.go file

package api

import (
        "github.com/gin-gonic/gin"
)

func ping(c *gin.Context) {
        c.JSON(200, gin.H{
                "message": "pong",
        })
}

func addRoute() {
        api := r.Group("/api")
        {
          api.GET("/ping", ping)
        }
}

Затем я снова запускаю dev_appserver.py ., но получаю эту ошибку:

ОШИБКА 2018-09-28 05: 17: 47,653 instance_factory.py:229] Не удалось создать приложение Go: (Выполненокоманда: /Users/gaco/.google-cloud-sdk/platform/google_appengine/goroot-1.9/bin/go-app-builder -app_base / Users / gaco / go / src / myproj -api_version go1 -arch 6 -dynamic -goroot /Users/gaco/.google-cloud-sdk/platform/google_appengine/goroot-1.9 -nobuild_files ^^ $ -incremental_rebuild -unsafe -print_extras_hash hello.go api / api.go)

2018/09 /28 14:17:47 go-app-builder: Сбой при разборе ввода: файл приложения api.go конфликтует с saМой файл импортирован из GOPATH

ПРЕДУПРЕЖДЕНИЕ 2018-09-28 05: 17: 47,654 instance.py:297] Не удалось получить PID экземпляра ERROR 2018-09-28 05: 17: 47,654 instance.py:300] У объекта '_GoBuildFailureRuntimeProxy' нет атрибута '_process'

В чем проблема?Как я могу решить это?

1 Ответ

0 голосов
/ 28 сентября 2018

Я только что понял, что это проблема, которая у меня когда-то была в моем собственном проекте App Engine.Проблема в том, что ваша папка api вложена в вашу папку myproject.SDK плохо обрабатывает импорт, и все в конечном итоге рекурсивно импортируется, поэтому возникает ошибка 2018/09/28 14:17:47 go-app-builder: Failed parsing input: app file api.go conflicts with same file imported from GOPATH.

По сути, вы должны быть уверены, что никогда не импортируете что-либо в каталог, что действительно раздражает.

Чтобы решить эту проблему, учитывая приведенную здесь информацию, вам необходимо разбить ее на более плоскую структуру каталогов.Примерно так:

myproject/main // or however you want to name it
myproject/api

С пустой папкой myproject.Тогда нет возможности его рекурсивного включения.

Для справки, у моего собственного проекта есть веб-сайт, api, db и сторонние api-структуры, поэтому моя структура такая, как вы ожидаете, учитывая решениеупоминается.например,

project/website
project/api
project/db
project/external

Обратите внимание, что и мой веб-сайт, и api являются отдельными службами, поэтому у них обоих есть свои app.yaml в соответствующих каталогах.Вы бы просто иметь один.Также в моем примере оба проекта импортируют db и external.

...