Моя 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'
В чем проблема?Как я могу решить это?