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

Ребята привет, вопросик такой: у нас ребята хотят использовать фичу

FastApi backgroundtasks, чтобы слать аудит логи в еластиксерч. Какие могут быть риски ? Можно ли будет потерять сообщения когда будет останавливаться кластер фаст апи воркеров ? И будет с новым кодом деплоиться ? Вообще я чувствую, мне хотелось бы заюзать как то nginx тут и просто проксировать траффик на еластиксерч, возможно на уровне нжинкс можно сделать какой то редирект трафика в бэкграунд режиме ? А сервера, которые за апи отвечают хотелось бы освободить от такой работы

17 ответов

22 просмотра

Потушил FastAPI - таска потерялась BackGround таск это буквально loop.create_later

Серж-ИзТанзании Автор вопроса
smqwe
Потушил FastAPI - таска потерялась BackGround тас...

то есть риск потери информации достаточно высок ? а как тогда лучше решить эту задачу ?

Серж-ИзТанзании Автор вопроса
smqwe
Потушил FastAPI - таска потерялась BackGround тас...

я не смотрел, но мне казалось, что в случае посылания сигнала fastapi, он должен как то джойниться к треду, который выполняется для выполнения бэкграунд тасков, чтобы предотвратить потерю тасков

Серж-ИзТанзании Автор вопроса
smqwe
Потушил FastAPI - таска потерялась BackGround тас...

я смотрел код, BackgroundTaskHandler - это просто тред со своим лупом....

Да, background таски в FastAPI это максимально примитивная наколеночная поделка, не ясно нахрена вообще существующая

Alex
Да, background таски в FastAPI это максимально при...

Мне кажется это такой ответ Чемберлену в виде сигналов джанги. И да, я знаю что они работают по разному.

Серж-ИзТанзании Автор вопроса
Alex
Да, background таски в FastAPI это максимально при...

а как советуешь организовать отсылку аудитлогов в еластиксерч ? я думал проксировать трафик через нжинкс, но задача - чтобы отсылка аудит логов не замедляла ответ апишки. либо уже думал через прометеус как то - складывать туда, и слать через прометеус......

Серж ИзТанзании
а как советуешь организовать отсылку аудитлогов в ...

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

Серж-ИзТанзании Автор вопроса
Alex
Так как это именно события аудита, то отправлять и...

либо, я думал, может организовать один еластиксерч именно как прокси, а уже с него проксировать на главный кластер еластиксерча.....

Серж ИзТанзании
а как советуешь организовать отсылку аудитлогов в ...

Поднимаешь локально (или где-то на другом сервере) rsyslog или что-то похожее, что умеет кешировать логи. Настраиваешь его для отправки логов в elasticsearch (вероятно не напрямую, а через logstash). Из приложения пуляешь в rsyslog сообщения по UDP (через SyslogHandler). Получишь минимальную задержку. Но есть вероятность некоторой потери сообщений, если rsyslog будет находится не на том же сервере где и приложение.

Серж-ИзТанзании Автор вопроса

ммм, поясни ?

Серж ИзТанзании
ммм, поясни ?

Ну у вьюхи есть зависимости. Они как-то создаются и потом освобождаются. Так вот если ты запустил БГ таск, они не освобождаются, чтобы юзаться там. Фича сомнительная потому что 1. ты не можешь одну зависимость юзать из нескольких тасков 2. Вряд ли она нужна все время выполнения таска, получится что мы занимаем ресурсы зря (например, коннекты к базе) 3. Веб сервер в норме не должен ничем заниматься кроме как обработкой запросов, иначе хз как масштабировать Но лучше уточнить в доке

Серж-ИзТанзании Автор вопроса
Tishka17
Ну у вьюхи есть зависимости. Они как-то создаются ...

но я так понимаю, что в любом случае эти фоновые задачи не гарантируют их выполнение если мы рестартим сервис ?

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

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

Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Коллеги, добрый вечер. Создаю коллекцию от TFPGMap, ключ - перечисление, значение - целое. Нужно отсортировать коллекцию по значению. Как это можно сделать?
Kirill Filippenok
11
Скажи а ты когда этот канал создавал ты уже дельфи не любил, или это со временем пришло?
Роман Лях (rgreat)
18
Привет, такой вопросик появился кажется ли вам что Rust слишком сложный/строгий для высокоуровневого программирования и слишком "безопасный"/строгий для низкоуровневого?
Крокант
10
Всем привет! Использую кастомное модальное диалоговое окошко, все по классике - mrOK, mrCancel как ModalResult. Однако есть нюанс - в главной форме есть универсальный обработч...
Олег Гранишевский
20
Карта сайта