From d6f919e589632882f14ba0ba573743d682d67695 Mon Sep 17 00:00:00 2001 From: Alexander Tesfamichael Date: Mon, 16 Oct 2023 12:32:47 +0200 Subject: [PATCH] feat(migrate-from-gcs): batch decoding --- src/bin/migrate-from-gcs.rs | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/src/bin/migrate-from-gcs.rs b/src/bin/migrate-from-gcs.rs index 8229184..0057005 100644 --- a/src/bin/migrate-from-gcs.rs +++ b/src/bin/migrate-from-gcs.rs @@ -195,6 +195,8 @@ async fn main() -> anyhow::Result<()> { let mut csv_reader = csv::Reader::from_reader(decoder); let mut iter = csv_reader.byte_records(); + let mut batch = Vec::new(); + while let Some(record) = iter.next().transpose().unwrap() { let execution_payload = { unsafe { @@ -213,7 +215,15 @@ async fn main() -> anyhow::Result<()> { } }; - futures::executor::block_on(decoded_tx.send(execution_payload)).unwrap(); + batch.push(execution_payload); + + if batch.len() == 32 { + for execution_payload in batch.drain(..) { + futures::executor::block_on(decoded_tx.feed(execution_payload)).unwrap(); + } + futures::executor::block_on(decoded_tx.flush()).unwrap(); + batch.clear(); + } } });