Я пытаюсь отладить его в течение нескольких часов безрезультатно.Я либо знаю, как Google, либо это необычная проблема.
У меня есть кластер Kubernetes Engine в облаке Google.Чтобы проверить это, я развернул простое приложение: https://github.com/iniside/uSpark Оно состоит из трех консольных приложений:
- GreeterServer - интерфейс с gRPC и конечными точками Google
- Greeter.Backend - серверная частьсо службой gRPC.
- uSpark - приложение клиентской консоли.
Все они используют .NET Core 2.1, gRPC 1.12 и C #.Kubernetes Engine: 1.10
Я уже пытался проверить, разрешен ли сервис DNS внутри кластера.Я также пытался вызывать сервис напрямую по его IP при создании канала.
Любой из них заканчивается:
Grpc.Core.RpcException: 'Status(StatusCode=Unavailable, Detail="Name resolution failure")'
GreeterServer пытается связаться с Greeter.Backend:
public override Task<HelloReply> SayHelloAgain(HelloRequest request, ServerCallContext context)
{
Channel channel = new Channel("grpc-greeter-backend.default.svc.cluster.local", 9000, ChannelCredentials.Insecure);
var backendClient = new GreeterBackend.GreeterBackendClient(channel);
var reply = backendClient.SayHelloFromBackend(new BackendHelloRequest { Name = "iniside" });
channel.ShutdownAsync().Wait(); //not neeed to wait, but easier to debug now.
return Task.FromResult<HelloReply>(new HelloReply { Message = "Hello Again " + request.Name + " " + reply.Message });
}
А это код моего бэкэнда:
class GreeterBackendImpl : GreeterBackend.GreeterBackendBase
{
public override Task<BackendHelloReply> SayHelloFromBackend(BackendHelloRequest request, ServerCallContext context)
{
return Task.FromResult<BackendHelloReply>(new BackendHelloReply { Message = "Hello " + request.Name + " From Backend"});
}
}
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Hello World!");
Server server = new Server
{
Services = { GreeterBackend.BindService(new GreeterBackendImpl()) },
Ports = { new ServerPort("127.0.0.1", 9000, ServerCredentials.Insecure) }
};
server.Start();
Console.WriteLine("Gretter server is linstening on port 50051");
Console.WriteLine("Press any key to stop server");
int read = Console.Read();
while (read < 0)
{
}
}
}
Конфигурация внешнего интерфейса:
apiVersion: v1
kind: Service
metadata:
name: esp-grpc-greeter
spec:
ports:
# Port that accepts gRPC and JSON/HTTP2 requests over HTTP.
- port: 80
targetPort: 9100
protocol: TCP
name: http2
selector:
app: esp-grpc-greeter
type: LoadBalancer
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: esp-grpc-greeter
spec:
replicas: 1
template:
metadata:
labels:
app: esp-grpc-greeter
spec:
containers:
- name: esp
image: gcr.io/endpoints-release/endpoints-runtime:1
args: [
"--http2_port=9100",
"--service=hellohorld3.endpoints.sa-game-206414.cloud.goog",
"--rollout_strategy=managed",
"--backend=grpc://127.0.0.1:9000"
]
ports:
- containerPort: 9100
- name: greeter
image: eu.gcr.io/sa-game-206414/greeter-service:v1
ports:
- containerPort: 8000
Конфигурация внутреннего интерфейса:
apiVersion: v1
kind: Service
metadata:
name: grpc-greeter-backend
spec:
ports:
# Port that accepts gRPC and JSON/HTTP2 requests over HTTP.
- port: 8080
targetPort: 9000
protocol: TCP
name: http2
- port: 9000
targetPort: 9000
protocol: TCP
name: http2900
selector:
app: grpc-greeter-backend
type: ClusterIP
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: grpc-greeter-backend
spec:
replicas: 1
template:
metadata:
labels:
app: grpc-greeter-backend
spec:
containers:
- name: greeter-backend
image: eu.gcr.io/sa-game-206414/greeter-backend:b1
ports:
- containerPort: 9000