Журнал из обработчиков gRPC / Go - PullRequest
1 голос
/ 26 мая 2020

Я пытаюсь отладить код путем печати / ведения журнала из функции gRPC / Go, но вывод не выводится на терминал.

fmt.Println() работает в моем методе main(), но не в обратных вызовах сервера. Как я могу печатать из этих обработчиков gRP C? Я открыт для других методов отладки, если есть другой подход.

Вот соответствующий код из моей функции main(). Здесь работает регистрация и печать:

func main() {
    ...

    lis, err := net.Listen("tcp", fmt.Sprintf("0.0.0.0:%s", os.Getenv("APP_PORT")))
    if err != nil {
        logger.Error(fmt.Sprintf("Failed start on port: %s", os.Getenv("APP_PORT")), err)
        log.Fatalf("Failed to start: %v", err)
    }

    opts := []grpc.ServerOption{}
    s := grpc.NewServer(opts...)
    pb.RegisterAuthServiceServer(s, &server{})

    // Register reflection service on gRPC server.
    reflection.Register(s)

    go func() {
        fmt.Println("Starting Server...")
        if err := s.Serve(lis); err != nil {
            log.Fatalf("failed to server: %v", err)
        }
    }()

    // Wait for Control C to exit
    ch := make(chan os.Signal, 1)
    signal.Notify(ch, os.Interrupt)

    // Run until a signal is received
    <-ch
    fmt.Println("")
    fmt.Println("Stopping the server")
    s.Stop()
    fmt.Println("Closing the listener")
    lis.Close()

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

func (*server) AuthUser(ctx context.Context, req *pb.AuthUserRequest) (*pb.AccessToken, error) {
    fmt.Println("AuthUser***")
    ...
...