以下のような構成でkubernetesをセットアップしています。
#---
kind: Service
apiVersion: v1
metadata:
name: myservice
spec:
selector:
app: my-service
ports:
- protocol: "TCP"
# Port accessible inside cluster
port: 8080
# Port to forward to inside the pod
targetPort: 80
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: my-service
spec:
replicas: 1
template:
metadata:
labels:
app: my-service
spec:
containers:
- name: my-service
image: my-custom-docker-regisry/my-service:latest
imagePullPolicy: Always
ports:
- containerPort: 8080
imagePullSecrets:
- name: regcred
そして私のイングレス:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: test-ingress
annotations:
nginx.ingress.kubernetes.io/ssl-redirect: "false"
spec:
rules:
- http:
paths:
- path: /myservice
backend:
serviceName: myservice
servicePort: 80
私がやろうとしたことは、Dockerレジストリからイメージをプルして、それをkubernetesで実行することです。ここでは1つのデプロイと1つのサービスを構成し、サービスをIngressで外部に公開しています。
MinikubeがIP 192.168.99.100で実行されています。アドレスcurl 192.168.99.100:80/myserviceでアプリケーションにアクセスしようとすると、502 Bad Gatewayが返されました。
なぜそれが起こったのか、または構成で何か間違ったことをしたのですか?よろしくお願いします!
あなたのイングレスはこのサービスをターゲットにしています:
serviceName: myservice
servicePort: 80
ただし、myservice
という名前のサービスは、8080
ではなくポート80
を公開します。
ports:
- protocol: "TCP"
# Port accessible inside cluster
port: 8080
# Port to forward to inside the pod
targetPort: 80
入力は、サービスによって公開されているポートの1つを指す必要があります。
また、サービス自体はポート80を対象としていますが、展開内のポッドは80ではなくポート8080を公開しているようです。
containers:
- name: my-service
image: my-custom-docker-regisry/my-service:latest
imagePullPolicy: Always
ports:
- containerPort: 8080
簡単に言えば、port
をtargetPort
でservice
と入れ替えて、次のようにすることができます。
8080
を公開します8080
をサービス名myservice
ポート80
で公開します。myservice
ポート80
にプロキシします。