forked from OtusTeam/OTUS-Kafka
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkafka_rest_requests.http
67 lines (48 loc) · 3.7 KB
/
kafka_rest_requests.http
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#### ЧТЕНИЕ И ЗАПИСЬ В ФОРМАТЕ STRING
# Записать сообщение в формате JSON в топик jsontest
curl -X POST -H "Content-Type: application/vnd.kafka.json.v2+json" \
--data '{"records":[{"value":{"foo":"bar"}}]}' "http://localhost:8082/topics/jsontest"
# Создать Consumer JSON в группе "my_json_consumer_group", начать читать с начала топика.
curl -X POST -H "Content-Type: application/vnd.kafka.v2+json" \
--data '{"name": "my_consumer_instance", "format": "json", "auto.offset.reset": "earliest"}' \
http://localhost:8082/consumers/my_json_consumer_group
# Подписаться на топик
curl -X POST -H "Content-Type: application/vnd.kafka.v2+json" --data '{"topics":["jsontest"]}' \
http://localhost:8082/consumers/my_json_consumer_group/instances/my_consumer_instance/subscription
# Прочитать данные
curl -X GET -H "Accept: application/vnd.kafka.json.v2+json" \
http://localhost:8082/consumers/my_json_consumer_group/instances/my_consumer_instance/records
# Удалить Consumer, чтобы не занимать ресурсы
curl -X DELETE -H "Content-Type: application/vnd.kafka.v2+json" \
http://localhost:8082/consumers/my_json_consumer_group/instances/my_consumer_instance
#### ЧТЕНИЕ И ЗАПИСЬ В ФОРМАТЕ AVRO
# Записать сообщение в формате Avro вместе со схемой
curl -X POST -H "Content-Type: application/vnd.kafka.avro.v2+json" \
-H "Accept: application/vnd.kafka.v2+json" \
--data '{"value_schema": "{\"type\": \"record\", \"name\": \"User\", \"fields\": [{\"name\": \"name\", \"type\": \"string\"}]}", "records": [{"value": {"name": "testUser"}}]}' \
"http://localhost:8082/topics/avrotest"
# Записать сообщение вместе с ключом в формате Avro (и ключ, и сообщение должны иметь одинаковый формат)
curl -X POST -H "Content-Type: application/vnd.kafka.avro.v2+json" \
-H "Accept: application/vnd.kafka.v2+json" \
--data '{"key_schema": "{\"name\":\"user_id\" ,\"type\": \"int\" }", "value_schema": "{\"type\": \"record\", \"name\": \"User\", \"fields\": [{\"name\": \"name\", \"type\": \"string\"}]}", "records": [{"key" : 1 , "value": {"name": "testUser"}}]}' \
"http://localhost:8082/topics/avrokeytest2"
# Создать Consumer Avro
curl -X POST -H "Content-Type: application/vnd.kafka.v2+json" \
--data '{"name": "my_consumer_instance", "format": "avro", "auto.offset.reset": "earliest"}' \
http://localhost:8082/consumers/my_avro_consumer_group
# Подписаться на топик
curl -X POST -H "Content-Type: application/vnd.kafka.v2+json" --data '{"topics":["avrotest"]}' \
http://localhost:8082/consumers/my_avro_consumer_group/instances/my_consumer_instance/subscription
# Прочитать данные в формате Avro. Схема подгрузится из SchemaRegistry автоматически
curl -X GET -H "Accept: application/vnd.kafka.avro.v2+json" \
http://localhost:8082/consumers/my_avro_consumer_group/instances/my_consumer_instance/records
# Удалить Consumer, чтобы не занимать ресурсы
curl -X DELETE -H "Content-Type: application/vnd.kafka.v2+json" \
http://localhost:8082/consumers/my_avro_consumer_group/instances/my_consumer_instance
#### МОНИТОРИНГ
# Список топиков
curl "http://localhost:8082/topics"
# Информация о топике
curl "http://localhost:8082/topics/avrotest"
# Информация о партициях топика
curl "http://localhost:8082/topics/avrotest/partitions"