Я пытаюсь отладить код путем печати / ведения журнала из функции 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***")
...