Как правильно заметили, будет сложно, так как переключать мозги на

асинхронщину - очень сложно.
Вам действительно нужна асинхронная модель для взаимодействия?
Может, проще будет начать с синхронной модели через какой-нибудь service-mesh типа Istio?
А потом уже переходить на kafka?

P.S. по моему опыту:
1) Да, лучше не использовать спринговых обвязок вокруг кафки, чем ближе к низкому уровню, тем надежнее.
2) Заранее предусмотреть canary deploy (что на kafka не очень очевидно)
3) Заранее придумать, что будете делать, если в проде кто-нибудь кафку уронит (а так точно будет) и какие-то события, накопившиеся в буфере на producer никуда не дойдут.
4) Очень внимательно изучите все настройки consumer/producer/topic/broker и напишите подробный документ по их значениям для ваших конкретных целей (а то цели у всех разные и насторойки из коробки рассчитаны больше на пропускную способность, чем на гарантии).
А уж после этого что будет в топике и как его обрабатывать - будет понятно )

2 ответов

13 просмотров

асинхронная модель - она сегодня везде, даже на rest сервисах. это скорее проблема не кафки, а reactive архитектур в целом. если есть опыт в reactive, то кафка но него ложится вполне ок.

IMO сравнивать kafka и istio (или linkerd etc) не совсем корректно. они скорее дополняют друг-друга чем конкурируют. kafka - это прежде всего data integration platform / write side. на istio можно вполне строить read side. весь value kafka (и kafka streams конкретно) - это data in motion. те когда одно же сообщение в топике это одновременно и запись в key-value store и нотификация другим сервисам - это круто и сразу решает целый ряд серьезных проблем. ничего похожего в istio et al нет и не будет, нужно пилить самому и это далеко не просто. в то же время на query side возможности каfka очень ограничены, и на istio можно вполне реализовать query side которая будет тащить данные из какой-нибудь read side database которая, в свою очередь, набивается из kafka

Похожие вопросы

Обсуждают сегодня

Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Привет!) Кто как юзает переменные в строках?) Чисто ради интереса Вот так: echo "У меня {$bananasAmount} бананов"; Или вот так: echo "У меня ${bananasAmount} бананов";
Виталий
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
разработчик ботов скидывает портфолио, боты которые он уже создал. А вот как узнать что это именно он их создал?
Gosudar
4
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Карта сайта