|
0 / 0 / 1
Регистрация: 29.11.2012
Сообщений: 52
|
||||||||||||||||
socketIO и фоновые задачи05.06.2020, 10:44. Показов 1100. Ответов 6
Всем привет, пытаюсь разобраться, как можно организовать фоновые задачи и скрестить их с веб сокетами.
Вот собственно постановка задачи: 1. Есть веб сокет сервер, который регистрирует пользователей с мобильного приложения.
Собственно вопрос, как правильно организовывать scheduler для сокетов, может можно прикрутить celery к socketIO. Мне нужно, что бы в фоновой задаче был доступен словарь: clients_connections: Dict[str, List[str]] = {}, который заполняется при коннекте клиентов. Задача должна по расписанию опрашивать базу на наличие новых не прочитанных уведомлений и рассылать их клиентам их этого словаря.
0
|
||||||||||||||||
| 05.06.2020, 10:44 | |
|
Ответы с готовыми решениями:
6
Socketio передача файлов Flask фоновые задачи Отложенные и фоновые задачи в android 8 и выше |
|
0 / 0 / 1
Регистрация: 29.11.2012
Сообщений: 52
|
|
| 06.06.2020, 16:05 [ТС] | |
|
Пробовал хранить в редиске, но она ругалась на что то не может хранить в себе объект socket, можно попробовать серилизовать этот словарь. Но на самом деле я хотел узнать, какие есть еще варианты организовать фоновые задачи в купе с socketio и кто как это делает.
0
|
|
|
|
||
| 06.06.2020, 16:09 | ||
|
0
|
||
|
Просто Лис
|
|
| 06.06.2020, 16:17 | |
|
Не, я говорил, что ваше решение с хранением открытых сокетов не масштабируется.
Храните в базе список пользователей, которые онлайн, а ещё лучше помечайте просто признаком. Воркеры держат соединения с веб-сокетами и с какой-то периодичностью обновляют статус "онлайн/нет". Так же проверяют в той же базе неотправленные сообщения. Задача, которая запускается по крону, синхронно забирает сообщения и, если пользователь онлайн, добавляет их в очередь. Иначе немедленно отправляет сообщение пушом.
0
|
|
|
0 / 0 / 1
Регистрация: 29.11.2012
Сообщений: 52
|
|||||||||||||||||||||||
| 08.06.2020, 00:31 [ТС] | |||||||||||||||||||||||
3. На сервере в функции send_notification принимаю данные и рассылаю по клиентам.
0
|
|||||||||||||||||||||||
|
0 / 0 / 1
Регистрация: 29.11.2012
Сообщений: 52
|
|||||||||||||||||||||
| 08.06.2020, 14:59 [ТС] | |||||||||||||||||||||
|
Такое ощущение, что emit из кастомной функции не работает.
INFO:socketio.server:received event "message" from ed4c631622864269b2c37e1616f66a0d [/] {'message': 'Task is connected'} А из send_notifications функции ничего не приходит, хотя в логе видно, что сообщение отправляется:
0
|
|||||||||||||||||||||
| 08.06.2020, 14:59 | |
|
Помогаю со студенческими работами здесь
7
VS2019 - как ее отучить запускать непрошеные фоновые задачи? Nodejs + socketio - ошибка доступа с другого хоста Как реализовать индивидуальный чат на SocketIo Flask?
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
|
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
|
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2.
Данный документ берёт данные из другого нетипового документа. . .
|
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
|
|
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: реализовать программный контроль на предмет проведения документа. . .
|
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача:
1. Реализовать контроль заполнения реквизита. . .
|
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение:
DISM / Online / Add-Capability / CapabilityName:WMIC~~~~
Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
|
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: при создании документов установить период списания автоматически. . .
|