【问题标题】:How to expose knative service to outside world via ingress如何通过 ingress 将 knative 服务暴露给外部世界
【发布时间】:2019-11-20 18:57:28
【问题描述】:

以下是我的 knative 服务示例

apiVersion: serving.knative.dev/v1
kind: Service
metadata:
  name: test-svc
spec:
  template:
    metadata:
      annotations:
        autoscaling.knative.dev/minScale: "1"
    spec:
      serviceAccountName: default
      containers:
      - image: ******************
        imagePullPolicy: IfNotPresent
        name: test-svc
        envFrom:
        - secretRef:
           name: test-env

kubectl get ksvc

NAME       URL                                   LATESTCREATED    LATESTREADY      READY     REASON
test-svc   http://test-svc.kube-system.kasl.io   test-svc-8v6gv   test-svc-8v6gv   True

网关+虚拟服务

apiVersion: networking.istio.io/v1alpha3
kind: Gateway
metadata:
  name: httpbin-gateway
spec:
  selector:
    istio: ingressgateway # use Istio default gateway implementation
  servers:
  - port:
      number: 80
      name: http
      protocol: HTTP
    hosts:
    - "*"
---
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
  name: httpbin
spec:
  hosts:
  - "*"
  gateways:
  - httpbin-gateway
  http:
  - match:
    - uri:
        prefix: /headers
    route:
    - destination:
        host: istio-ingressgateway.istio-system.svc.cluster.local

如果我在集群内 curl -v http://test-svc.kube-system.kasl.io 它工作得很好 下面是我的 knative 服务示例

apiVersion: serving.knative.dev/v1
kind: Service
metadata:
  name: test-svc
spec:
  template:
    metadata:
      annotations:
        autoscaling.knative.dev/minScale: "1"
    spec:
      serviceAccountName: default
      containers:
      - image: ******************
        imagePullPolicy: IfNotPresent
        name: test-svc
        envFrom:
        - secretRef:
           name: test-env

kubectl get ksvc

NAME       URL                                   LATESTCREATED    LATESTREADY      READY     REASON
test-svc   http://test-svc.kube-system.kasl.io   test-svc-8v6gv   test-svc-8v6gv   True

网关+虚拟服务

apiVersion: networking.istio.io/v1alpha3
kind: Gateway
metadata:
  name: httpbin-gateway
spec:
  selector:
    istio: ingressgateway # use Istio default gateway implementation
  servers:
  - port:
      number: 80
      name: http
      protocol: HTTP
    hosts:
    - "*"
---
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
  name: httpbin
spec:
  hosts:
  - "*"
  gateways:
  - httpbin-gateway
  http:
  - match:
    - uri:
        prefix: /headers
    route:
    - destination:
        host: istio-ingressgateway.istio-system.svc.cluster.local

如果我这样做 curl -v http://test-svc.kube-system.kasl.io 在集群内它的工作

现在我想将这些服务公开给外部集群

【问题讨论】:

    标签: kubernetes google-kubernetes-engine kubernetes-ingress istio knative


    【解决方案1】:

    Knative 使用一个共享的入口网关来服务 Knative 服务网格内的所有传入流量,它是 knative-serving 命名空间下的 knative-ingress-gateway 网关。默认情况下,它使用 istio-system 命名空间下的 Istio 网关服务 istio-ingressgateway 作为其底层服务。您可以将服务替换为您自己的服务,如下所示[1],更详细的步骤请参阅链接[2]。

    [1]https://knative.dev/docs/serving/setting-up-custom-ingress-gateway/ [2]https://starkandwayne.com/blog/public-traffic-into-knative-on-gke/

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2021-08-30
      • 2016-11-03
      • 1970-01-01
      • 1970-01-01
      • 2019-11-21
      • 2020-01-28
      • 2015-10-31
      • 2019-02-12
      相关资源
      最近更新 更多