在微服务架构里面,每个小服务都是由很多节点组成,节点的添加删除故障希望能对下游透明,因此有必要引入一种服务的自动注册和发现机制,而 consul 提供了完整的解决方案,并且内置了对 GRPC 以及 HTTP 服务的支持

总体架构

  • 服务调用: client 直连 server 调用服务
  • 服务注册: 服务端将服务的信息注册到 consul 里
  • 服务发现: 客户端从 consul 里发现服务信息,主要是服务的地址
  • 健康检查: consul 检查服务器的健康状态

服务注册

服务端将服务信息注册到 consul 里,这个注册可以在服务启动可以提供服务的时候完成

服务发现

客户端从 consul 里发现服务信息,主要是服务的地址

健康检查

google.golang.org/grpc/health/grpc_health_v1.HealthServer

完整代码参考:



参考链接


添加客服微信grey0805,共享更多信息!