Consul GRPC 健康检查失败问题

2020-11-14 22:19:24 +08:00
 wunonglin

Consul 注册的信息

reg := api.AgentServiceRegistration{
	ID:      strconv.FormatInt(time.Now().UnixNano(), 10),
	Name:    name,
	Address: listen,
	Port:    port,
	Check:   &api.AgentServiceCheck{
		GRPC:     fmt.Sprintf("%v:%v/%v", listen, port, name),
		Interval: "5s",
		Notes:    "Consul check service health status.",
		DeregisterCriticalServiceAfter: "10s",
	},
}

我按照 https://www.consul.io/docs/discovery/checks 里的 grpc 检查里,写了个 proto

syntax = "proto3";

package grpc_health_v1;
option go_package = ".;grpc_health_v1";

message HealthCheckRequest {
    string service = 1;
}

message HealthCheckResponse {
    enum ServingStatus {
        UNKNOWN = 0;
        SERVING = 1;
        NOT_SERVING = 2;
        SERVICE_UNKNOWN = 3;  // Used only by the Watch method.
    }
    ServingStatus status = 1;
}

service Health {
    rpc Check(HealthCheckRequest) returns (HealthCheckResponse);

    rpc Watch(HealthCheckRequest) returns (stream HealthCheckResponse);
}

我用 BloomRPC 和自己写的 client 都能正常访问这个 Check 方法,但是注册上了 Consul 却显示失败

1674 次点击
所在节点    Go 编程语言
7 条回复
axex
2020-11-16 14:18:39 +08:00
grpc 的 health check 是不需要你实现的,grpc 的库中有 google.golang.org/grpc/health/grpc_health_v1,你直接 import 然后 RegisterHealthServer(grpcServer, health.NewServer())就行了
wunonglin
2020-11-16 14:32:54 +08:00
@axex #1
我现在改了下代码引入了,但是&api.AgentServiceCheck 里的 GRPC 是要怎么填,

是 ip:port 还是 ip:port/service_name 还是 ip:port//grpc_health_v1.Health ?我都试了都不行
axex
2020-11-16 14:52:25 +08:00
@wunonglin ip:port 就行了,如果不行的检查一下 ip,看看 consul 能否正常访问
wunonglin
2020-11-16 15:01:04 +08:00
@axex #3

grpc: addrConn.createTransport failed to connect to {127.0.0.1:8080 0 <nil>}. Err :connection error: desc = "transport: Error while dialing dial tcp 127.0.0.1:8080: connect: connection refused". Reconnecting...

提示这个,但是我自己写了一个 client 测试的话是可以连接上来的
axex
2020-11-16 15:14:12 +08:00
@wunonglin consul 和 grpc server 在同一台机器上面?不是的话 consul 是无法访问的,最好改成内网 ip 或者改用 ttl 检查
wunonglin
2020-11-16 15:42:52 +08:00
@axex #5

OK 了,我 tm 人傻了,consul 是在 docker 上的,然后我填的 check 地址是 127,,我在本地部署了个 consul 可以了
wunonglin
2020-11-16 15:46:05 +08:00
@axex #5 consul 他这文档有坑吧,也没说直接引用官方的 func,还以为要自己写,搜了网上的教程,压根没人提过,我硬是研究了 2 天,浪费一个美好的周末 😑

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/725314

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX