grpc-go как справиться с примером отмены

Я смотрю на пример grpc, но я не понимаю этот пример. Может ли кто-нибудь объяснить это мне?

пример расположен по адресу: https://github.com/grpc/grpc-go/blob/master/examples/features/cancellation/server/main.go#L52

func (s *server) BidirectionalStreamingEcho(stream pb.Echo_BidirectionalStreamingEchoServer) error {
    for {
        in, err := stream.Recv()
        if err != nil {
            fmt.Printf("server: error receiving from stream: %v\n", err)
            if err == io.EOF {
                return nil
            }
            return err
        }
        fmt.Printf("echoing message %q\n", in.Message)
        stream.Send(&pb.EchoResponse{Message: in.Message})
    }
}

Может кто-нибудь объяснить процесс этого исполнения, как он называется? спасибо.


person faker    schedule 04.04.2019    source источник


Ответы (1)


клиент вызывает метод

    stream, err := c.BidirectionalStreamingEcho(ctx)

поэтому сервер начнет вызов BidirectionalStreamingEcho

person faker    schedule 04.04.2019