gRPC服务认证有几种实现思路
- gRPC通信层使用SSL/TLS认证
- gRPC服务提供的接口中认证
- 使用注册中心的认证
通信层基于SSL/TLS认证方式
参考这里:
https://segmentfault.com/a/1190000007933303
大致思路是,gRPC通信层使用证书:
服务端创建服务增加参数
creds, err := credentials.NewServerTLSFromFile("../../keys/server.pem", "../../keys/server.key")
s := grpc.NewServer(grpc.Creds(creds))
客户端链接增加参数
creds, err := credentials.NewClientTLSFromFile("../../key