215 похожих чатов

Господа, вот такая странная ситуация: имеется приложение на тарантуле, суть

которого — принять и обработать данные. Принимает по http, кладет в бд, которая исполняет роль FIFO-буфера, а потом в другом потоке оттуда их достает и обрабатывает. Обычно обьем буфера — максимум 1000 штук. Но иногда что-то случается, и буфер сначала вырастает до десятков тысяч, а потом обработка останавливается вообще.
Этого не случается на низкой нагрузке, но стабильно случается, если пакетов больше десятка в секунду. Но от нагрузки напрямую не зависит — не упираемся ни в процессор, ни в память, ни в диск, ни в сеть. И нагрузка всегда одна и та же, нет пиков. Просто часами работает нормально, а потом оп, и все.
У кого-нибудь есть идеи, куда копать? Тарантул 1.10

2 ответов

11 просмотров

а может наоборот? файбер обработчик где-то дохнет (а вы за ним плохо следите), а потом и буфер растет

vvzvlad-Зайцев Автор вопроса

в общем, дело было в http-запросах, сохраняющих данные в инфлюксе которые по недосмотру, блокировали пайплайн обработки.

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

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

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Карта сайта