Задать вопрос
@UsmanovTim

Что лучше выбрать для взаимодействия в микросервисной архитектуре? MessageBroker или REST?

Добрый день! Проектирую систему, которая в будущем будет держать большие нагрузки. До этого проектировал только монолитные решения. Это мой первый опыт проектирования микросервисов. Стоит дилемма что выбрать для общения сервисов друг с другом. Вижу 2 варианта.
1) REST - понятный, простой в документировании, но есть точка отказа в виде API Gateway
2) RPC через message broker(пока на rabbitmq) - удобный в масштабировании и балансировке, но также есть точка отказа в виде брокера.
Оба варианта со своими преимуществами и недостатками. И как такового перевеса в выборе нет. Хочу поинтересоваться что у Вас в компании используется в коммуникации сервисов? И есть ли какие -то подводные камни в данных методах?
  • Вопрос задан
  • 963 просмотра
Подписаться 1 Средний 2 комментария
Решения вопроса 1
Зависит от того что именно за данные (для какой цели) будут передаваться и между кем и кем.
Rest как и любой другой синхронный метод взаимодействия несёт плюсы:
+ Сравнительно быстрая реакция на запрос и ответ. (как правило от запроса до получения ответа менее секунды)
+ Очень прост в использовании, нет никаких проблем с поддержкой на клиенте
+ Очень простая инфраструктура (в минимальном варианте она не нужна вообще)
+ Всё хорошо изучено. Та же аутентификация и авторизация очень легко реализуется в рамках http.
+ Достаточно легко разрабатывать и тестировать
+ Есть grpc и openapi - нет никакой проблемы с документированием такого API.
+ В http запрос с каким-нибудь multipart form data может спокойно быть размером в десятки мегабайт, а может и больше - полезно при загрузке файлов.
И минусы:
- Не понятно что делать, в случае недоступности ответной стороны
- При неправильной реализации клиента (политики ретраев) - можно легко заддосить сервер

Всякие разнообразные брокеры сообщений тоже имеют свои плюсы:
+ Строгая очерёдность обработки данных (событий) из коробки
+ В случае недоступности ответной стороны - брокер у себя может хоть несколько дней держать данные
+ Все политики ретраев реализуются на стороне брокера
+ Если это rabbit, то можно разные сложные механики рассылки и маршрутизации реализовать
+ Если это кафка или какой-то другой лог, то можно вычитывать события повторно

Но есть и минусы:
- Инфраструктура обычно сложнее
- Достаточно большие задержки
- Использовать можно будет только у себя внутри - внешнему клиенту (браузер, мобильное приложение, публичный API) такое дать не получится.
- Сложнее разграничивать в правах.
- Сложно разрабатывать и тестировать. На примере той же кафки - подключиться к топику и записать в него что-то через гуй - это отдельный челендж.
- Запросы должны быть небольшими (сотни кб)
Ответ написан
Пригласить эксперта
Ответы на вопрос 2
petermzg
@petermzg
Самый лучший программист
Тут зависит от выбранного подхода.
Для примера:
Front/Moblie -> (REST API) -> API Gateway -> (GRPC) -> Service.
Сами сервисы между собой только нотификациями, через Message Broker (RebbitMq)
Ответ написан
mayton2019
@mayton2019
Bigdata Engineer
Современные брокеры такие как Kafka не имеют одной точки отказа. Можешь их рассмотреть вместо кролика.

REST является синхронным по своему дизайну. Тоесть ты вызываешь rest метод и ждешь ответа именно на этот
вызов в отличие от MQ где ты просто шлешь уведомления и тебе безразличен отклик. Поэтому MQ обычно
быстрее и дешевле когда у тебя идут тысячи и миллионы месседжей в секунду.

В REST можно делать пакетные (batch) методы. Это ускоряет обработку при массовом обслуживании
но и коды ошибок будут тоже возвращаться в виде batch ошибок и их надо соотв также пачкой и обработать
а это все усложняет бизнес-логику.
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

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