var*_*ius 7 go protocol-buffers grpc
我有一个gRPC客户端和一个服务器,当我运行它们时,它们似乎运行正常,但当我尝试用客户端拨打服务器时,我收到一个错误:
"Error": {
"code": 14,
"message": "all SubConns are in TransientFailure"
},
Run Code Online (Sandbox Code Playgroud)
不知道它是什么.我试图找到谷歌的解决方案,没有成功.
有任何想法吗?这是我的服务器代码:
lis, err := net.Listen("tcp", fmt.Sprintf("%s:%d", cfg.Host, cfg.Port))
if err != nil {
logger.Critical(ctx, "failed to listen: %v", err)
} else {
logger.Info(ctx, "[userserver] running at %s:%d", cfg.Host, cfg.Port)
}
grpcServer := grpc.NewServer()
userServer := userserver.New()
pb.RegisterDomainServer(grpcServer, userServer)
rpcErr := grpcServer.Serve(lis)
if rpcErr != nil {
logger.Critical(ctx, "failed to serve: %v", rpcErr)
}
Run Code Online (Sandbox Code Playgroud)
顺便说一句,这里的服务器显示日志:
2018/02/08 07:03:37.603287 INFO:[userserver]在localhost:3001上运行
和客户:
conn, err := grpc.Dial(c.serverAddr, grpc.WithInsecure())
if err != nil {
return err
}
defer conn.Close()
client := pb.NewDomainClient(conn)
_, err = client.Dispatch(ctx, &pb.Command{
Name: command,
Payload: payload,
})
Run Code Online (Sandbox Code Playgroud)
这是端口buff
service Domain {
rpc Dispatch(Command) returns (Response);
}
message Command {
string name = 1;
bytes payload = 2;
}
message Response {}
Run Code Online (Sandbox Code Playgroud)
服务器正在侦听该端口吗?
// Most linux
lsof -i :3001
// OSX
lsof -iTCP -sTCP:LISTEN -P
Run Code Online (Sandbox Code Playgroud)
您是否将客户端连接到正确的地址?
c.serverAddr 应为“127.0.0.1:3001”