Насколько дорого в токио спавнить блокирующие вызовы? Взял для работы базу

rocksdb и там только блокирующие апи.
Написал такие обертки для каждого вызова к rocksdb и общаюсь через канал
fn spawn_task_put(
base: Arc<rocksdb::DBWithThreadMode<rocksdb::MultiThreaded>>,
) -> mpsc::Sender<(Vec<u8>, Vec<u8>, oneshot::Sender<anyhow::Result<()>>)> {
let (tx, mut rx) = mpsc::channel::<(Vec<u8>, Vec<u8>, oneshot::Sender<anyhow::Result<()>>)>(
CHANNEL_BUFFER_LEN,
);
task::spawn_blocking(move || {
while let Some((key, val, out)) = rx.blocking_recv() {
let res = base.put(key, val);
// ignore is closed
let _ = out.send(res.map_err(|e| anyhow::Error::new(e)));
}
});
tx
}

2 ответов

26 просмотров

Емнип примерно как поток создавать

Дмитрий-Бондаренко Автор вопроса
Пух
Емнип примерно как поток создавать

Я вот подумал что вообще хрень натворил. Наверное профитнее всего отказатся от мультипоточной версии базы тоесть исключить потери на вызовы в кернел для блокировок (если на чтение тоже блокируется). Выделить процесс под базу и общаться с ней через канал.

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

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

Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
7
Всем привет. Не понимаю, в чём тут шутка юмора. Убирается только разрешение на send_messages. А send_media_messages остаётся. Как сделать, чтобы оба убирались? await b...
Alexander
2
Есть тут кто занимается разработкой серваков майна? Или знакомые
meow *
3
'frakturBold' => ['𝖆', '𝖇', '𝖈', '𝖉', '𝖊', '𝖋', '𝖌', '𝖍', '𝖎', '𝖏', '𝖐', '𝖑', '𝖒', '𝖓', '𝖔', '𝖕', '𝖖', '𝖗', '𝖘', '𝖙', '𝖚', '𝖛', '𝖜', '𝖝', '𝖞', '𝖟', '𝕬', '𝕭', '𝕮', '𝕯'...
Roma
4
Есть ли лимиты на кол-во вебхук по домену? Стоит в данный момент 900+ ботов и бывает бот перестает отвечать (не приходят вебхуки) 🐒 Помогает только перезапуск
ᅠ [ Кому не ответил, дублируйте ]
11
Товарищи, здравствуйте Подскажите, пожалуйста, может кто-нибудь сталкивался с такой задачей Через вебапку можно сканировать qr-код, а есть ли возможность считывать nfc?
Artem Stormageddon
8
а что делать если тебя убивают на картах?
Yarik yarik kyda ti lezesh
43
Визуальное отображение моделей таблиц sql какое посоветуете?
Shen
7
Карта сайта