он каждую транзакцию будет обрабатывать отдельно чтобы получить максимальную скорость.Но в итоге он обрабатывает пару минут и глохнет, почему такое может быть?
let stream = provider.subscribe_pending_txs().await.unwrap();
stream
.for_each_concurrent(None, |tx_hash| {
let provider_clone = provider.clone();
let pancake_factory = pancake_factory.clone();
async move {
let result = provider_clone.get_transaction(tx_hash).await;
let tx = match result {
Ok(x) => match x {
Some(x) => x,
None => return,
},
Err(x) => {
println!("{:?}", x);
return;
}
};
infra::process_tx(&tx, &provider_clone, &pancake_factory).await;
}
})
.await;
если ты забиваешь треды которые вычитывают асинк задачи то у тебя оно будет застревать. spawn_blocking может помочь немного, но если у тебя задача дольше обрабатываются чем поступают то магии не произойдет и сообщения перестанут обрабатываться (среднее время обработки будет расти до бесконечности)
но у меня литерали 32 ядра, и каждая тарнзакция должна обрабатыавться не больше секунды-2
Обсуждают сегодня