Плохой шлюз в приложении Rails с настройкой Kubernetes

Я пытаюсь настроить приложение Rails в кластере Kubernetes (который создается с помощью k3d на моем локальном компьютере.

k3d cluster create --api-port 6550 -p "8081:80@loadbalancer" --agents 2

kubectl create deployment nginx --image=nginx

kubectl create service clusterip nginx --tcp=80:80

      # apiVersion: networking.k8s.io/v1beta1 # for k3s < v1.19
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: nginx
  annotations:
    ingress.kubernetes.io/ssl-redirect: "false"
spec:
  rules:
  - http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: nginx
            port:
              number: 80

Я могу запустить Ingress, который правильно отображает запущенное развертывание Nginx («Добро пожаловать в nginx!») (Я взял этот пример отсюда: https://k3d.io/usage/guides/exposing_services/

Итак, я знаю, что моя установка работает (с nginx).

Теперь я просто хочу указать этот вход в свое приложение Rails, но всегда получаю сообщение «Плохой шлюз». (Я также пытался указать на другие мои службы (elasticsearch, kibana, pgadminer), но всегда получаю «Плохой шлюз».

Я вижу, что мое приложение Rails работает в последних строках моего Dockerfile (http: // localhost:62333/):

      EXPOSE 3001:3001
CMD rm -f tmp/pids/server.pid && bundle exec rails s -b 0.0.0.0 -p 3001

Почему у моего API "плохой шлюз", а у Nginx нет?

Это как-то связано с моими селекторами и метками, созданными с помощью kompose convert?

Это мое полное развертывание Rails-API:

      kubectl apply -f api-deployment.yml -f api.service.yml -f ingress.yml

api-deployment.yml

      apiVersion: apps/v1
kind: Deployment
metadata:
  annotations:
    kompose.cmd: kompose convert -c --file metashop-backend/docker-compose.yml --file metashop-backend/docker-compose.override.yml
    kompose.version: 1.22.0 (HEAD)
  creationTimestamp: null
  labels:
    io.kompose.service: api
  name: api
spec:
  replicas: 1
  selector:
    matchLabels:
      io.kompose.service: api
  strategy:
    type: Recreate
  template:
    metadata:
      annotations:
        kompose.cmd: kompose convert -c --file metashop-backend/docker-compose.yml --file metashop-backend/docker-compose.override.yml
        kompose.version: 1.22.0 (HEAD)
      creationTimestamp: null
      labels:
        io.kompose.network/metashop-net: 'true'
        io.kompose.service: api
    spec:
      containers:
        - env:
            - name: APPLICATION_URL
              valueFrom:
                configMapKeyRef:
                  key: APPLICATION_URL
                  name: env
            - name: DEBUG
              value: 'true'
            - name: ELASTICSEARCH_URL
              valueFrom:
                configMapKeyRef:
                  key: ELASTICSEARCH_URL
                  name: env
          image: metashop-backend-api:DockerfileJeanKlaas
          name: api
          ports:
            - containerPort: 3001
          resources: {}
      #     volumeMounts:
      #       - mountPath: /usr/src/app
      #         name: api-claim0
      # restartPolicy: Always
      # volumes:
      #   - name: api-claim0
      #     persistentVolumeClaim:
      #       claimName: api-claim0
status: {}

api-service.yml

      apiVersion: v1
kind: Service
metadata:
  annotations:
    kompose.cmd: kompose convert -c --file metashop-backend/docker-compose.yml --file metashop-backend/docker-compose.override.yml
    kompose.version: 1.22.0 (HEAD)
  creationTimestamp: null
  labels:
    app: api
    io.kompose.service: api
  name: api
spec:
  type: ClusterIP
  ports:
    - name: '3001'
      protocol: TCP
      port: 3001
      targetPort: 3001
  selector:
    io.kompose.service: api
status:
  loadBalancer: {}

ingress.yml

      apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: api
  annotations:
    ingress.kubernetes.io/ssl-redirect: "false"
spec:
  rules:
  - http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: api
            port:
              number: 3001

configmap.yml

      apiVersion: v1
data:
  APPLICATION_URL: localhost:3001
  ELASTICSEARCH_URL: elasticsearch
  RAILS_ENV: development
  RAILS_MAX_THREADS: '5'
kind: ConfigMap
metadata:
  creationTimestamp: null
  labels:
    io.kompose.service: api-env
  name: env

Надеюсь, я ничего не пропустил.

заранее спасибо

РЕДАКТИРОВАТЬ: добавлена ​​конечная точка, запрошенная в комментарии:

вид: конечная точка

      kind: Endpoints
apiVersion: v1
metadata:
  name: api
  namespace: default
  labels:
    app: api
    io.kompose.service: api
  selfLink: /api/v1/namespaces/default/endpoints/api
subsets:
  - addresses:
      - ip: 10.42.1.105
        nodeName: k3d-metashop-cluster-server-0
        targetRef:
          kind: Pod
          namespace: default
          apiVersion: v1
    ports:
      - name: '3001'
        port: 3001
        protocol: TCP

1 ответ

Решение

Проблема была в Dockerfile:

Я не определил, поэтому мне не удалось увидеть никаких ошибок в журналах модуля.

После того, как я добавил ENV RAILS_LOG_TO_STDOUT true Я видел такие ошибки, как database xxxx does not exist

Другие вопросы по тегам