我在 golang 中创建了一个示例 gRPC 客户端和服务器(使用了 protobufs)。我了解 golang 中的并发模型。但是,我试图了解服务器中的并发模型,该服务器接受来自同一客户端(客户端上的多个 goroutine)/多个客户端的并行请求。
进一步来说:
- 当一个新的 gRPC 调用到来时,服务器是否会创建一个新的 goroutine?
- 这些 goroutine 共享哪些数据?是否
grpcServer.Serve
为跨 goroutine 共享的数据设置边界,即之前设置的所有内容都是共享的?(我正在考虑Java中的线程共享全局数据的线程)