(процессов, вебсокетов)
Мне нужно отправить в каждую информацию, получить ответ, потом повторить. Т. е. сначала я жду ответа от всех, и только потом начинаю снова посылать запросы, причём ответ жду с таймаутом.
Я не уверен, как это лучше сделать.
Можно порождать тред на каждого клиента. Можно вместо этого их спаунить в асинк-тасках, наверное? Но я не могу сходу придумать, как в Rust это сделать на них. Ещё есть actix с акторами, которые, вроде как, тоже подходят под проблему.
let mut connections: Vec<_> = /* */; connections.iter_mut().for_each(|x| x.set_nonblocking().unwrap()); // Vec<bool> with the length of the connections. let mut is_ok = BitVec; let mut ok_resp = Vec::new(); loop { let deadline = Instant::now() + SOME_DURATION; while Instant::now() < deadline { for idx in (0..connections.len()).rev() { let c = connections[idx]; if !is_ok.get(idx) { match c.read(buf) { Ok(n) => { is_ok.set(idx); ok_resp.push((c.socket(), n)); }, Err(_) => (), } } } } for idx in (0..connections.len()).rev() { if !is_ok.get(idx) { connections.swap_remove(idx); } } is_ok.truncate(connections.len()); is_ok.unset_all(); /* На оставшиеся фигачишь дальше */ }
https://docs.rs/tokio/0.2.22/tokio/sync/struct.Barrier.html
что делать с фьючами если таймаут райзнулся?
Обсуждают сегодня