kubectl expor aparentemente expõe timeout / conexões incorretas

1

Eu tenho um arquivo de pod que se parece com isso:

apiVersion: v1
kind: Pod
metadata:
  name: test-api
  labels:
    app: web
spec:
  containers:
    - name: test-api-container
      image: cmgvieira/test-api:latest
  imagePullSecrets:
    - name: regsecret

Está funcionando corretamente:

$ kubectl get pods
NAME          READY     STATUS    RESTARTS   AGE
test-api      1/1       Running   0          10d

Eu posso acessá-lo usando kubectl port-forward test-api 3000:80 , em seguida, wget localhost:3000 .

Quando eu o exponho usando kubectl expose -f test-api-pod.yml --port=80 --target-port=80 --type=LoadBalancer , o serviço é criado com sucesso:

$ kubectl describe service test-api
Name:                   test-api
Namespace:              default
Labels:                 app=web
Selector:               app=web
Type:                   LoadBalancer
IP:                     100.XXX.XXX.XXX
LoadBalancer Ingress:   XYZ-ABC.us-east-1.elb.amazonaws.com
Port:                   <unset> 80/TCP
NodePort:               <unset> 32310/TCP
Endpoints:              <none>
Session Affinity:       None
Events:
  FirstSeen     LastSeen        Count   From                    SubObjectPath   Type            Reason                  Message
  ---------     --------        -----   ----                    -------------   --------        ------                  -------
  7m            7m              1       {service-controller }                   Normal          CreatingLoadBalancer    Creating load balancer
  7m            7m              1       {service-controller }                   Normal          CreatedLoadBalancer     Created load balancer

Mas não consigo acessar com wget XYZ-ABC.us-east-1.elb.amazonaws.com porque o tempo limite.

Eu pensei que isso poderia ser um problema com o hostname, então eu adicionei XYZ-ABC.us-east-1.elb.amazonaws.com ao meu arquivo "hosts" local, fazendo com que ele resolvesse 127.0.0.1 , e o servidor responde muito bem.

Alguém sabe o que pode estar causando esse problema?

Além disso, observe que quando uso a imagem normal de nginx em vez do meu próprio servidor de aplicativos, tanto port-forward quanto expose funcionam bem.

FWIW:

$ kubectl version
Client Version: version.Info{Major:"1", Minor:"5", GitVersion:"v1.5.3", GitCommit:"029c3a408176b55c30846f0faedf56aae5992e9b", GitTreeState:"clean", BuildDate:"2017-02-15T06:40:50Z", GoVersion:"go1.7.4", Compiler:"gc", Platform:"linux/amd64"}
Server Version: version.Info{Major:"1", Minor:"5", GitVersion:"v1.5.2", GitCommit:"08e099554f3c31f6e6f07b448ab3ed78d0520507", GitTreeState:"clean", BuildDate:"2017-01-12T04:52:34Z", GoVersion:"go1.7.4", Compiler:"gc", Platform:"linux/amd64"}
    
por Guilherme Vieira 17.03.2017 / 23:22

0 respostas

Tags