gotsrpc/example/monitor/main.go
Kevin Franklin Kim 7faf7e4c98 feat: add monitor
2022-05-04 11:16:04 +02:00

59 lines
1.3 KiB
Go

package main
import (
"context"
"fmt"
"net/http"
"os/exec"
"strings"
"time"
"github.com/foomo/gotsrpc/v2"
"github.com/foomo/gotsrpc/v2/example/monitor/service"
)
func init() {
// set custom monitor handler
gotsrpc.Monitor = func(w http.ResponseWriter, r *http.Request, args, rets []interface{}, stats *gotsrpc.CallStats) {
// you might want to use channels or routines here as to not block the actual call
go func(stats *gotsrpc.CallStats) {
fmt.Printf(
"Monitor: %s.%s [%dμs|%dμs|%dμs]\n",
stats.Service, stats.Func, stats.Unmarshalling.Microseconds(), stats.Execution.Microseconds(), stats.Marshalling.Microseconds(),
)
}(stats)
}
}
func main() {
fs := http.FileServer(http.Dir("./client"))
ws := service.NewDefaultServiceGoTSRPCProxy(&service.Handler{})
mux := http.NewServeMux()
mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
switch {
case strings.HasPrefix(r.URL.Path, "/service/"):
ws.ServeHTTP(w, r)
default:
fs.ServeHTTP(w, r)
}
})
go func() {
time.Sleep(time.Second)
_ = exec.Command("open", "http://127.0.0.1:3000").Run()
call()
}()
panic(http.ListenAndServe("localhost:3000", mux))
}
func call() {
c := service.NewDefaultServiceGoTSRPCClient("http://127.0.0.1:3000")
{
res, _ := c.Hello(context.Background(), "Hello World")
fmt.Println(res)
}
}