go-zero/example/tracing/edge/main.go

62 lines
1.1 KiB
Go
Raw Normal View History

2020-07-26 17:09:05 +08:00
package main
import (
"flag"
"log"
"net/http"
"zero/core/conf"
"zero/core/logx"
"zero/core/service"
"zero/example/tracing/remote/portal"
2020-07-31 11:14:48 +08:00
"zero/rest"
"zero/rest/httpx"
2020-07-26 17:09:05 +08:00
"zero/rpcx"
)
var (
configFile = flag.String("f", "config.json", "the config file")
client *rpcx.RpcClient
)
func handle(w http.ResponseWriter, r *http.Request) {
conn, ok := client.Next()
if !ok {
log.Fatal("no server")
}
greet := portal.NewPortalClient(conn)
resp, err := greet.Portal(r.Context(), &portal.PortalRequest{
Name: "kevin",
})
if err != nil {
httpx.WriteJson(w, http.StatusInternalServerError, http.StatusText(http.StatusInternalServerError))
} else {
httpx.OkJson(w, resp.Response)
}
}
func main() {
flag.Parse()
var c rpcx.RpcClientConf
conf.MustLoad(*configFile, &c)
client = rpcx.MustNewClient(c)
2020-07-31 11:45:16 +08:00
engine := rest.MustNewServer(rest.RestConf{
2020-07-26 17:09:05 +08:00
ServiceConf: service.ServiceConf{
Log: logx.LogConf{
Mode: "console",
},
},
Port: 3333,
})
defer engine.Stop()
2020-07-31 11:14:48 +08:00
engine.AddRoute(rest.Route{
2020-07-26 17:09:05 +08:00
Method: http.MethodGet,
Path: "/",
Handler: handle,
})
engine.Start()
}