C # gRPC внутри кластера kubernetes не может преобразовать DNS-имя в другой сервис - PullRequest
0 голосов
/ 09 июня 2018

Я пытаюсь отладить его в течение нескольких часов безрезультатно.Я либо знаю, как 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

1 Ответ

0 голосов
/ 09 июня 2018

Я исправил проблему, и это было в два раза.Сначала, как предположил @spender, я изменил адреса gRPC на 0.0.0.0 как на бэкэнд, так и на фронтэнд.

Но изменения не были обнаружены кластером.Потому что все это время он тянул неправильные изображения.

Каждый раз, когда я вносил изменения, я удалял старые изображения со старыми тегами (как локально, так и в GCR).Создал новое изображение с тем же удаленным репозиторием и тегом и отправил их в GCR.

По какой-то причине изображения не были обновлены.

...