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

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

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

2 ответов

12 просмотров

асинхронная модель - она сегодня везде, даже на 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

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

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

Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
3
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
5
у кого сколько оперативы на базе данных ?
АДИЛЬБЕК
4
Через бот апи возможно получить ID стикерпака? Не ссылку.
Vexylon [АФК до 09.09]
5
Привет Хочу сделать аналог iCloud’а для своих проектов, чтобы пользовательская информация хранилась в облаке, была доступна во всех сервисах, её можно было подсасывать везде)...
Виталий
9
В тг можно спарсить всех кто пишет в группе? Если список участников скрыт
S
3
код Event::listen('cms.page.display', function (&$content, $slug, $page, $html) { if (is_object($content)) { dump($content); } else { dump($s...
Point 111
3
Всем привет. Не понимаю, в чём тут шутка юмора. Убирается только разрешение на send_messages. А send_media_messages остаётся. Как сделать, чтобы оба убирались? await b...
Alexander
2
Карта сайта