| Crates.io | simple-concurrent-get |
| lib.rs | simple-concurrent-get |
| version | 0.3.1-r2504 |
| created_at | 2024-11-18 07:13:17.936677+00 |
| updated_at | 2025-04-16 16:07:12.169782+00 |
| description | Simply make multiple concurrent HTTP GET requests |
| homepage | https://github.com/ParkSnoopy/simple-concurrent-get |
| repository | https://github.com/ParkSnoopy/simple-concurrent-get |
| max_upload_size | |
| id | 1451888 |
| size | 113,610 |
Make multiple concurrent HTTP GET requests with ease.
concurrent_get#[tokio::main]
async fn main() {
let request_urls = vec![
"https://example.com/1",
"https://example.com/2",
"https://example.com/3",
"https://example.com/4",
// ...
];
// for example: maximum 3 concurrent request
let request_results = simple_concurrent_get::concurrent_get(request_urls, 3);
let _: Vec<_> = request_results
.await
.map(|result| match result {
Ok(response) => {
let url = response.url().to_owned();
let bytes = futures_executor::block_on(async{ response.bytes().await }).unwrap();
println!("Successfully got '{}' with '{}' bytes of content", url, bytes.len())
},
Err(e) => eprintln!("{}", e),
})
.collect();
}
concurrent_get_foreach#[tokio::main]
async fn main() {
let request_urls = vec![
"https://example.com/1",
"https://example.com/2",
"https://example.com/3",
"https://example.com/4",
// ...
];
// for example: maximum 3 concurrent request
let _: Vec<_> = simple_concurrent_get::concurrent_get_foreach(request_urls, 3,
|result| match result {
Ok(response) => {
let url = response.url().to_owned();
let bytes = futures_executor::block_on(async{ response.bytes().await }).unwrap();
println!("Successfully got '{}' with '{}' bytes of content", url, bytes.len())
},
Err(e) => eprintln!("{}", e),
}
)
.await
.collect();
}