Рассмотрим пример из базы кода gRPC Go:
func main() {
// Set up a connection to the server.
conn, err := grpc.Dial(address, grpc.WithInsecure())
if err != nil {
log.Fatalf("did not connect: %v", err)
}
defer conn.Close()
c := pb.NewGreeterClient(conn)
// Contact the server and print out its response.
name := defaultName
if len(os.Args) > 1 {
name = os.Args[1]
}
r, err := c.SayHello(context.Background(), &pb.HelloRequest{Name: name})
if err != nil {
log.Fatalf("could not greet: %v", err)
}
log.Printf("Greeting: %s", r.Message)
}
При использовании службы gRPC из другой службы, какой должна быть область подключения (conn
)? Я предполагаю, что он должен иметь сходство с объемом обрабатываемого запроса в службе потребителей, но мне еще предстоит найти какую-либо документацию по этому поводу. Следует ли мне использовать здесь пул подключений?
E.G.
- Служба потребителей gRPC получает запрос
- установить соединение с сервисом gRPC (напрямую или через пул)
- сделать n запросов к службе gRPC
- закрыть соединение gRPC (или отпустить обратно в пул)