0

我正在 GKE 中测试 Knative,这是我想做的:

在此处输入图像描述

但是,我在“default-broker-filter”的日志中收到以下错误:

caller: "http/transport.go:508"   
error: "Post http://helloworld-python.knative-samples.svc.cluster.local: dial tcp: lookup helloworld-python.knative-samples.svc.cluster.local on 10.0.0.10:53: no such host"   
level: "warn"   
logger: "fallback"   
msg: "got an error from receiver fn" 

我使用这个官方教程使用以下命令安装 Knative:

kubectl apply --selector knative.dev/crd-install=true \
--filename https://github.com/knative/serving/releases/download/v0.12.0/serving.yaml \
--filename https://github.com/knative/eventing/releases/download/v0.12.0/eventing.yaml \
--filename https://github.com/knative/serving/releases/download/v0.12.0/monitoring.yaml

kubectl apply --filename https://github.com/knative/serving/releases/download/v0.12.0/serving.yaml \
--filename https://github.com/knative/eventing/releases/download/v0.12.0/eventing.yaml \
--filename https://github.com/knative/serving/releases/download/v0.12.0/monitoring.yaml

这是我用来在 python 中安装触发器和服务 hello world 的 yaml 模板:

# Namespace for sample application with eventing enabled
apiVersion: v1
kind: Namespace
metadata:
  name: knative-samples
  labels:
    knative-eventing-injection: enabled
---
apiVersion: serving.knative.dev/v1
kind: Service
metadata:
  name: helloworld-python
  namespace: knative-samples
spec:
  template:
    spec:
      containers:
        - image: gcr.io/knative-samples/helloworld-python
          env:
            - name: TARGET
              value: "Python Sample v1"

---
# Knative Eventing Trigger to trigger the helloworld-go service
apiVersion: eventing.knative.dev/v1alpha1
kind: Trigger
metadata:
  name: my-service-trigger
  namespace: knative-samples
spec:
  broker: default
  filter:
    attributes:
      type: dev.knative.samples.helloworld
  subscriber:
    ref:
      apiVersion: serving.knative.dev/v1
      kind: Service
      name: helloworld-python

然后我创建一个 pod 来执行我的 curl 命令:

kubectl --namespace knative-samples run curl --image=radial/busyboxplus:curl -it

curl -v "default-broker.knative-samples.svc.cluster.local" \
  -X POST \
  -H "Ce-Id: 536808d3-88be-4077-9d7a-a3f162705f79" \
  -H "Ce-specversion: 0.3" \
  -H "Ce-Type: dev.knative.samples.helloworld" \
  -H "Ce-Source: dev.knative.samples/helloworldsource" \
  -H "Content-Type: application/json" \
  -d '{"msg":"Hello World from the curl pod."}'

你能告诉我这是怎么回事,因为我整个周末都没有找到任何线索吗?

谢谢,

4

2 回答 2

1

您是否启用了集群本地网关?如果不是,那么这可能是它不起作用的原因。详情见以下链接:

https://knative.dev/docs/install/installing-istio/

于 2020-02-27T14:54:37.387 回答
0

您的应用程序仅接受GET请求,您可以在此处看到 - https://github.com/knative/docs/blob/master/docs/serving/samples/hello-world/helloworld-python/app.py

正如您在cloudevents规范中看到的 - https://github.com/cloudevents/spec/blob/master/http-webhook.md#21-delivery-request

传递请求的 HTTP 方法必须是 POST。

您必须使用POST方法来触发您的服务。

如果你想修复它,你有两个简单的选择:

  1. 您可以将服务的图像更改为event_display( gcr.io/knative-releases/github.com/knative/eventing-sources/cmd/event_display)

  2. 您可以更改应用程序的代码,并将L7从更改@app.route('/')@app.route('/', methods=['GET', 'POST'])

于 2020-03-04T10:15:56.293 回答