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

У меня задача: написать брокер сообщений. Очереди и потребители. Очереди

поддерживают приоритеты. Очередь отдает сообщения, только обработчикам с соответствующими характеристиками (навыки). Обработчики принимаю заявки, далее освобождаются и заново подписываются на очереди. Так как я пишу веб на питоне, то я привык к сервисам без состояния. В случае с BEAM я представляю очереди и обработчики в виде GenServer'ов. Но нельзя же хранить все в памяти, хранить сообщения на диске тоже надо. Я могу хранить сообщения на диске, а в памяти держать только хвост очереди, но я не знаю как интегрироваться по такой структуре. Я знаю, что в Е есть свои собственные подходы для работы с БД. И я бы хотел про них почитать. Читая RabbitMQ я не нашел GenServer'ы, но честно говоря, мне пока сложно что-то там найти. Какие есть способы хранения очередей на диске? Стоит ли мне использовать Mnesia? И как лучше сочетать стейт в хранилище и стейт в процессах. Какие паттерны для этого есть и где про них можно прочитать? Заранее спасибо

2 ответов

5 просмотров

Для начала напиши такие очереди в памяти.

Сначала просто напиши простейший ген_сервер, который держит одну очередь в памяти и раздает первым попавшимся всё подряд. Затем уже допиливай фичи, вроде приоритетов, тегов, ёжиков, трусов в горошек. С такой формулировкой задачи ты захлебнешься даже не успев ничего запустить работающего.

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

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

Ребят в СИ можно реализовать ООП?
Николай
32
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный  TFilestream  не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
16
добрый день. Подскажите, есть сайт на 1.4.7 и я хочу обновиться, особо ничего не меняя. мне выбирать версию 1.4.35 или третью ветку? и можно ли обновлять "как есть", или нужно...
Digital Cat
12
народ, плиз хелп, всю голову сломал себе уже... разве может быть так, что GetProcAddress( GetModuleHandle( "kernel32.dll" ), "SetThreadDescription" ) вернёт ненулевое значение...
Iluha Companets
12
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный TFilestream не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
8
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Коллеги, я тут для личных нужд пошел ставить MQTT сервер, пощупал mosquitto, но ужаснулся отсутствию такой банальности, как HTTP API для посмотреть список топиков. А тут что,...
Maksim Lapshin
14
Карта сайта