mirror of
https://git.asonix.dog/asonix/pict-rs
synced 2025-01-23 09:55:50 +00:00
Add metrics to object storage body streams
This commit is contained in:
parent
49d3037358
commit
cde4a72203
2 changed files with 28 additions and 4 deletions
|
@ -405,9 +405,9 @@ impl Store for ObjectStore {
|
|||
return Err(status_error(response).await);
|
||||
}
|
||||
|
||||
Ok(Box::pin(crate::stream::map_err(
|
||||
response.bytes_stream(),
|
||||
payload_to_io_error,
|
||||
Ok(Box::pin(crate::stream::metrics(
|
||||
"pict-rs.object-storage.get-object-request.stream",
|
||||
crate::stream::map_err(response.bytes_stream(), payload_to_io_error),
|
||||
)))
|
||||
}
|
||||
|
||||
|
@ -434,7 +434,11 @@ impl Store for ObjectStore {
|
|||
));
|
||||
}
|
||||
|
||||
let mut stream = response.bytes_stream().into_streamer();
|
||||
let stream = std::pin::pin!(crate::stream::metrics(
|
||||
"pict-rs.object-storage.get-object-request.stream",
|
||||
response.bytes_stream()
|
||||
));
|
||||
let mut stream = stream.into_streamer();
|
||||
|
||||
while let Some(res) = stream.next().await {
|
||||
let mut bytes = res.map_err(payload_to_io_error)?;
|
||||
|
|
|
@ -3,6 +3,26 @@ use futures_core::Stream;
|
|||
use std::{pin::Pin, time::Duration};
|
||||
use streem::IntoStreamer;
|
||||
|
||||
use crate::future::WithMetrics;
|
||||
|
||||
pub(crate) fn metrics<S>(name: &'static str, stream: S) -> impl Stream<Item = S::Item>
|
||||
where
|
||||
S: Stream,
|
||||
S::Item: 'static,
|
||||
{
|
||||
streem::from_fn(|yielder| {
|
||||
async move {
|
||||
let stream = std::pin::pin!(stream);
|
||||
let mut streamer = stream.into_streamer();
|
||||
|
||||
while let Some(item) = streamer.next().await {
|
||||
yielder.yield_(item).await;
|
||||
}
|
||||
}
|
||||
.with_metrics(name)
|
||||
})
|
||||
}
|
||||
|
||||
pub(crate) fn make_send<S>(stream: S) -> impl Stream<Item = S::Item> + Send
|
||||
where
|
||||
S: Stream + 'static,
|
||||
|
|
Loading…
Reference in a new issue