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

Всем привет, у меня вопрос. Использую actix. У меня есть асинхронный

сервер.
У меня есть состояние которое завернуто в Data<Arc<Mutex<State>>>
я завернул в не асинхронный мютекс состояние.
Есть роуты, один из них очень тяжелый, и там очень часто используется State,
я написал скрипт, который дает 100+ запросов за секунду по этому роуту,
и возникает проблема что запросы начинают обрабатываться, но это затягивается до вечности и если дать просто любой запрос на сервер, то он не обрабатывается а просто вечно грузится, может ли это быть из-за не асинхронного мютекса?
Я еще до конца не преисполнился в асинхронности и в мютексах и не совсем до конца понимаю из-за чего это, но подозреваю что это происходит из-за того что где-то в токио в планировщике задач параллельно блокируется мой State одновременно и из-за этого возникает проблема зависания. Поможет ли мне тут асинхронный мютекс? Или же мне использовать лучше сообщения? А может делить состояния на каждый запрос как это было показано в доках токио?

8 ответов

11 просмотров

состояние актора завернуто в мьютекс?

Удерживается ли lock guard мьютекса через какие-либо await? Например: let state = state.lock().unwrap(); smth.await; state.do_smth()

Даня- Автор вопроса
Alexey Sokolovskiy
Удерживается ли lock guard мьютекса через какие-ли...

да мой mutex используется в некоторых асинхрнных функциях если вы про это

Даня
да мой mutex используется в некоторых асинхрнных ф...

Важно не только в асинхронных функциях, а как именно Универсальный рецеп +- такой: Если мьютекс держится поверх какого-то из .await, то его надо делать асинхронным Если нет - не надо

Вообще, если данные часто читаются, но редко изменяются, можно сделать так: Mutex<Arc<T>>, делать копию этого Arc под мьютексом и сразу освобождать его. Или, как вариант, использовать крейт arc-swap, который позволяет делать атомарный свап Arc. Если надо менять состояние, то можно сделать обновлённую копию, потом сделать std::mem::swap под блокировкой, освободить блокировку и дропнуть копию. Таким образом можно уменьшить критические секции. Ещё есть вариант разделить State на куски и каждый кусок защитить мьютексом, кусок выбирать через хэш каких-то входных данных запроса. Тогда 2 потока смогут одновременно работать, если у них хэши не совпадают. Асинхронный мьютекс поможет только другим запросам, которые вообще не используют эти данные.

Angelicos Phosphoros
Вообще, если данные часто читаются, но редко измен...

Если данные часто читаются, но редко меняются нужен RwLock

!van
Если данные часто читаются, но редко меняются нуже...

С RwLock может случится, что будет writer starving (если у нас несправедливая реализация, например, в Linux). Вообще, зависит от ситуации. Если нам обязательно нужно новые данные возвращать, rwlock хорош, но в большинстве веб-сервисов eventual consistency приемлем. И в таких случаях есть смысл максимально сократить продолжительность критической секции.

Даня- Автор вопроса

Асинхронные мютексы и рвлоки помогли справится с этой проблемой

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

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

А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Где в Астане можно купить мясо для шашлыков?
Dancing Іңұқәһүғө
21
Добрый день подскажите пожалуйста может кто то сталкивался с ошибками Sentry 22.10.0 развернутым из helm чарт в Kubernetes? Изначально 3 дня назад очень стало много событий ух...
Tire4 Finist Devops
1
;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, стандартный ;вызов процедуры ;option casemap:no...
Егор Анелькин
1
почому оно не работает?
Vi Chapmann Chapmann
19
всем привет почти закончил курс После него можно писать свою операционку? Какие библиотеки надо использовать и куда дальше копать для изучения
Linus
19
Так а кто может спарсить всех участников чата? Идишники
Magic
18
Карта сайта