如何使Kubernetes入口终止SSL和代理服务



我在裸金属上与kubernetes一起部署了CentOS7。一切都很好。但是,我想让Ingress工作。因此,简而言之,我想做的是从入口内部终止SSL,并在入口和我的服务之间具有平淡的HTTP。这就是我所做的:

1(我编织以允许hostNetwork

2(我有一个按照:

设置的入口控制器
apiVersion: extensions/v1beta1
kind: DaemonSet
metadata:
  name: nginx-ingress-controller
  namespace: ingress-nginx
  labels:
    k8s-app: nginx-ingress-lb
    kubernetes.io/cluster-service: "true"
spec:
  template:
    metadata:
      labels:
        k8s-app: nginx-ingress-lb
        name: nginx-ingress-lb
    spec:
      hostNetwork: true
      terminationGracePeriodSeconds: 60
      serviceAccountName: nginx-ingress-serviceaccount
      nodeSelector:
        role: edge-router
      containers:
      - image: quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.12.0
        name: nginx-ingress-lb
        imagePullPolicy: Always
        readinessProbe:
          httpGet:
            path: /healthz
            port: 10254
            scheme: HTTP
        livenessProbe:
          httpGet:
            path: /healthz
            port: 10254
            scheme: HTTP
          initialDelaySeconds: 10
          timeoutSeconds: 1
        # use downward API
        env:
          - name: POD_NAME
            valueFrom:
              fieldRef:
                fieldPath: metadata.name
          - name: POD_NAMESPACE
            valueFrom:
              fieldRef:
                fieldPath: metadata.namespace
        ports:
          - containerPort: 80
            hostPort: 80
          - containerPort: 443
            hostPort: 443
        args:
          - /nginx-ingress-controller
          - --default-backend-service=$(POD_NAMESPACE)/default-http-backend
          - --enable-ssl-passthrough
          # - --default-ssl-certificate=$(POD_NAMESPACE)/tls-certificate
        volumeMounts:
          - name: tls-dhparam-vol
            mountPath: /etc/nginx-ssl/dhparam
      volumes:
        - name: tls-dhparam-vol
          secret:
            secretName: tls-dhparam

请注意守护程序和NodeSelector。还有hostNetwork = true,以便我的kubernetes节点将打开80和443以聆听路由(。

所以我试图访问http://foo.bar.com,毫不奇怪,什么都没有。我刚刚获得default backend - 404页面。我需要入学规则....

3(所以我创建了这样的Ingress规则:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: hub
  annotations:
    kubernetes.io/ingress.class: "nginx"
    ingress.kubernetes.io/ssl-redirect: "true"
    nginx.ingress.kubernetes.io/rewrite-target: /
    nginx.org/ssl-services: "hub"
spec:
  tls:
  - hosts:
    - foo.bar.com
    secretName: tls-dhparam
  rules:
  - host: foo.bar.com
    http:
      paths:
      - path: /
        backend:
          serviceName: hub
          servicePort: 8000

所以它很棒!...对于http ...当我在http://foo.bar.com上访问我的节点时,我可以访问我的服务(HUB(并可以登录。但是,由于必须登录它,只能执行HTTPS ....

所以我的问题是,当我将浏览器切换到https://foo.bar.com时,我最终都会获得default backend - 404页面。

查看上面介绍的证书,我看到它是由kubernetes创建的:

Kubernetes Ingress Controller Fake Certificate
Self-signed root certificate

检查我的秘密:

$ kubectl -n ingress-nginx get secrets
NAME                                       TYPE                                  DATA      AGE
default-token-kkd2j                        kubernetes.io/service-account-token   3         12m
nginx-ingress-serviceaccount-token-7f2sq   kubernetes.io/service-account-token   3         12m
tls-dhparam                                Opaque                                1         8m

我在做什么错?

问题是,使用a pem 文件似乎不起作用(并且与之相关的错误都没有明显的错误(。

当我切换到TLS CERT/键时,它可以使用:

kubectl create secret tls tls-certificate --key my.key --cert my.cer

在您的示例中,看来您的Ingress并未明确声明metadata.namespace。如果在tls-dhparam Secret中最终进入default名称空间,则在ingress-nginx名称空间中,这将是问题。Ingress ES的TLS秘密应与Ingress相同的命名空间。

相关内容

  • 没有找到相关文章

最新更新