簡體   English   中英

NGINX入口控制器的默認后端

[英]NGINX Ingress Controller's Default Backend

我有一個正在運行測試的kubernetes集群,並且已經使用此法師設置了NGINX Ingress控制器: quay.io/kubernetes-ingress-controller/nginx-ingress-controller : 0.11.0

就我到目前為止所了解的Ingress Controllers而言,該設置似乎可以正常運行,只是Ingress Controller的默認后端路徑默認為/ 我當前的問題是我進入了默認路徑也是/的服務(港口)。 因此,我無法使用該服務,因此我總是會收到默認的后端404響應。 我曾嘗試將Harbor服務的入口路徑更改為/以外的其他值,但是在調用更改的路徑后,Harbor返回200頁,但上面只有一個Loading...字符串(我不知道Harbor中是否有硬編碼的東西)這樣就可以停止它,而不喜歡/ ?以外的任何路徑。

然后我的問題是,是否可以將默認后端的默認路徑更改為/以外的其他內容? 還是完全刪除默認后端? (我在線閱讀了無法刪除默認后端的信息)。 那我有什么選擇呢?

---編輯:使用的配置---

Ingress Conroller YAML:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: nginx-ingress-controller
  namespace: ingress-nginx
spec:
  replicas: 1
  selector:
    matchLabels:
      app: ingress-nginx
  template:
    metadata:
      labels:
        app: ingress-nginx
      annotations:
        prometheus.io/port: '10254'
        prometheus.io/scrape: 'true'
    spec:
      serviceAccountName: nginx-ingress-serviceaccount
      containers:
        - name: nginx-ingress-controller
          image: quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.11.0
          args:
            - /nginx-ingress-controller
            - --default-backend-service=$(POD_NAMESPACE)/default-http-backend
            - --default-ssl-certificate=$(POD_NAMESPACE)/default-tls-secret
            - --configmap=$(POD_NAMESPACE)/nginx-configuration
            - --tcp-services-configmap=$(POD_NAMESPACE)/tcp-services
            - --udp-services-configmap=$(POD_NAMESPACE)/udp-services
            - --annotations-prefix=nginx.ingress.kubernetes.io
          env:
            - name: POD_NAME
              valueFrom:
                fieldRef:
                  fieldPath: metadata.name
            - name: POD_NAMESPACE
              valueFrom:
                fieldRef:
                  fieldPath: metadata.namespace
          ports:
          - name: http
            containerPort: 80
          - name: https
            containerPort: 443
          livenessProbe:
            failureThreshold: 3
            httpGet:
              path: /healthz
              port: 10254
              scheme: HTTP
            initialDelaySeconds: 10
            periodSeconds: 10
            successThreshold: 1
            timeoutSeconds: 1
          readinessProbe:
            failureThreshold: 3
            httpGet:
              path: /healthz
              port: 10254
              scheme: HTTP
            periodSeconds: 10
            successThreshold: 1
            timeoutSeconds: 1

入口YAML:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: harbor
  annotations:
    kubernetes.io/ingress.class: "nginx"
    nginx.ingress.kubernetes.io/ssl-redirect: "false"
spec:
  tls:
  - hosts:
    - k8s-dp-2
  rules:
  - host: k8s-dp-2
    http:
      paths:
      - path: /
        backend:
          serviceName: ui
          servicePort: 80
      - path: /v2
        backend:
          serviceName: registry
          servicePort: repo
      - path: /service
        backend:
          serviceName: ui
          servicePort: 80

服務YAML:

apiVersion: v1
kind: Service
metadata:
  name: ui
spec:
  ports:
    - port: 80
  selector:
    name: ui-apps

設置實際上是正確的,並且通過nginx入口控制器到Harbor的入口路由現在按預期工作。

為了明確起見,k8s測試群集在Windows 10計算機上托管的Virtualbox VM(Centos 7)上運行,當我今天早晨再次嘗試使用Harbor URL(在重新啟動Windows 10計算機和Virtualbox VM主機之后)時,Harbor頁面開始加載。

所以我猜的答案是需要重新啟動(但是不確定為什么-我不清楚在應用k8s資源更改后是否有需要重新啟動k8s節點的情況)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM