Привет! Может у кого есть идеи как сделать: - у нас

есть микросервис который публикует мессаджи в SNS, и из SNS они направляются в очередь (SQS)
- эту очередь слушает другой микросервис (Lambda), который их процессит, во время процессинга он использут одно API, которое лучше не дергать более 60 раз в минуту
- если от первого микросервиса прилетает слишком много мессаджей (бывает что их генерится 500 в минуту) - то нам нужно как-то “притормозить” чтобы “слушающий” микросервис процессил их не все сразу, а по 30-60 в минуту

Варианты решения:
- ставить custom random delay во время отправки сообщения в SNS - к сожалению невозможно, custom delay опция есть только если шлешь напрямую в SQS (sqs.sendMessage) а в SNS такого нет (sns.publish)
- поставить concurrency limit у второго микросервиса в 1 - у меня почему-то в результате 1 мессадж оказался в deadletter queue, ну и concurrency=1 не гарантирует что оно в минуту не сделает больше 60

Я перетестирую сегодня с concurrency=1 но все равно это не идеально, - как можно притормозить получение мессаджей из SNS/SQS?

4 ответов

14 просмотров

Привет! Я похожую проблему решал через написание сервиса на питоне, правда сервис ещё смотрел на другие SQS очереди и в зависимости от того насколько они загружены слал или тормозил отправку. Для лямбды мне тоже интересно как это можно сделать, как вариант сделать что-то типа счетчика отправок в динаме и если лимит достигнут, то лямбда должна подождать. Но это костыль) С concurrency у меня тоже не пошло, лямбды под нагрузкой троттлят и падают.

Andrey Terekhov
Привет! Я похожую проблему решал через написание с...

Как вариант, если лимит отправки во второй микросервис исчерпан, то можно сделать change_message_visibility у сообщения в sqs и выходить из лямбды. То есть сделать сообщение недоступным на какой-то интервал и когда оно вернётся заново попробовать его обработать.

А нельзя написать старый добрый сервис на условном ec2/ecs который будет обрабатывать очередь с комфортной скоростью?

Сходу вижу два варианта: 1) настройка sqs event source для lambda function. Нужно выбрать подходящие значения для группировки сообщений - batch size и batch window

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

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

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
1. https://www.kaggle.com/code/ahmadrezagholami2001/housing-estimation-linear-regression 2. https://www.kaggle.com/code/ahmadrezagholami2001/uncovering-quality-in-wines-logis...
Ahmadreza
1
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта