3

我想通过 Kafka Rest Proxy 生成一个 kafka 主题。我在模式注册表中创建了一个 JSON 模式,我希望所有消息都根据注册的模式进行验证,如果它们与模式不匹配,则会被拒绝。

我的架构

{
  "type": "object",
  "properties": {
    "foo": {
      "type": "string",
    },
    "bar": {
      "type": "number" 
    }
  }
}

此架构已正确注册并分配了版本 1。然后我尝试为两者生成一条数据类型错误的消息foobar但该消息被接受。

curl --location --request POST 'http://localhost:8082/topics/test' \
--header 'Content-Type: application/vnd.kafka.jsonschema.v2+json' \
--header 'Accept: application/vnd.kafka.v2+json' \
--data-raw '{
    "value_schema_id": 1,
    "records": [
        {
            "value": {
                "foo": 10,
                "bar":"not a number"
            }
        }
    ]
}'

请注意,我正在生成test具有关联模式的主题,但无论如何都会接受错误消息。我还尝试添加"value_schema_id": 1以确保在有效负载中引用了架构,但仍然接受错误消息。

但是,如果我传递 JSON 模式,因为value_schema它按预期工作

{
    "value_schema": "{\"type\": \"object\",\"properties\": {\"foo\": {\"type\": \"string\"},\"bar\": {\"type\": \"number\"}}}",
    "records": [
        {
            "value": {
                "foo": "10",
                "bar": "1"
            }
        }
    ]
}

回复

{
    "error_code": 42203,
    "message": "Conversion of JSON to Object failed: Failed to convert JSON using JSON Schema: #/bar: expected type: Number, found: String"
}

问题:是否可以在生成消息时引用现有的模式 id 而不必每次都传递整个 JSON 模式?

4

1 回答 1

1

是的,这是可能的。您必须按照以下方式启用它的值、键或两者:

confluent.value.schema.validation=true 
confluent.key.schema.validation=true

此外,在您的 JSON 请求中,您可以指定架构的 ID。以下面为例,来说明我在说什么:

{
  "key_schema_id": 1234,
  "value_schema_id: 56789,
  "records": [
    {
      "key": "key123",
      "value": "my_simple_string_value_example"
    }
  ]
}

在哪里:

key_schema_id

是模式注册表中键模式的 ID。通过为其设置适当的值,将保证仅接受具有符合该 ID 标识的模式的密钥的消息。

相似地:

value_schema_id

是模式注册表中值模式的 ID。通过为其设置适当的值,将保证仅接受具有符合该 ID 标识的模式的值的消息。

希望这有助于阐明一些观点。

干杯,

爱德华多·庞佐尼

于 2021-04-21T10:02:15.163 回答