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

Всем привет! Есть приложение ASGI, запускается в проде через gunicorn.

Там запускается несколько worker'ов. И при старте идет подключение к вебсокету. При получении сообщения обновляется бд и отправляется уведомление. Но так как воркеров несколько, уведомление отправляется несколько раз (почти в одно и то же время приходит).
Как можно сделать обработку сообщений от вебсокета только в одном воркере? Или проще просто отдельный скрипт написать и запустить в фоне?

5 ответов

7 просмотров

Ну вообще клиент должен держать Коннект с одним сокетом и получать оттуда уведомления. Если он держит несколько коннектов, то сервер работает правильно ц те.я

Я все таки ещё раз спрошу: как связано число воркеров и то, что уведомление приходит несколько раз?

Алексей- Автор вопроса
Tishka17
Я все таки ещё раз спрошу: как связано число ворке...

Каждый воркер при старте подключается к вебсокету, а при новом сообщении оно приходит всем воркерам примерно в одно время, и каждый из них отсылает уведомление дальше, т.к. бд ещё не обновлена (на стороне вебсокет сервера это asyncio.gather)

Алексей
Каждый воркер при старте подключается к вебсокету,...

Ну допустим. Пока проблемы не вижу. Клиент все равно держит Коннект с одним воркером же

Алексей- Автор вопроса
Tishka17
Ну допустим. Пока проблемы не вижу. Клиент все рав...

Как с одним?) Возможно я не так сказал Каждый воркер gunicorn подключается к одному и тому же вебсокету другого приложения, поэтому при новом сообщении оно приходит всем воркерам gunicorn одновременно

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

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

А чем вам питонисты не угодили?😂
.
79
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Ты просто гитлеровскую эстетику плохо понимаешь. Он же всё под Цезаря делал. А это как бы запрещённый приём в политике. Пиджаки они зачем все носят? Чтобы показать что они тип...
Ivan Kropotkin
4
а чем лучше всего сделать глобальный лок, если много нодов, до сотни? ну то есть мне надо, чтобы некоторые операции с объектом не происходили одновременно. перемещение между н...
Д. П.
15
Hi guys, I'm looking for a good LLM course. Is there any course to learn LLMs in advanced? I'm aiming to use them in my apps, so a perfect course in my openion, is not only a ...
Taha
14
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
База данных не поможет. Шифрование не поможет. Какие там ещё варианты? Накидывайте.
КТ315
20
А табстоп это сообщение от окна или от элемента управления?
The Bird of Hermes
18
Легче писать на C++ чем на C, если полностью не изучать C++, а знать только основное?
Алмаз
8
Карта сайта