mirror of
https://git.asonix.dog/asonix/pict-rs
synced 2025-01-05 17:21:28 +00:00
Take at most 2048 variants and proxies during each cleanup job
This commit is contained in:
parent
e3fa0e02df
commit
c65b49339f
2 changed files with 35 additions and 2 deletions
src
|
@ -158,7 +158,9 @@ async fn outdated_variants(repo: &ArcRepo, config: &Configuration) -> Result<(),
|
||||||
let now = time::OffsetDateTime::now_utc();
|
let now = time::OffsetDateTime::now_utc();
|
||||||
let since = now.saturating_sub(config.media.retention.variants.to_duration());
|
let since = now.saturating_sub(config.media.retention.variants.to_duration());
|
||||||
|
|
||||||
let mut variant_stream = repo.older_variants(since).await?.into_streamer();
|
let variant_stream = repo.older_variants(since).await?;
|
||||||
|
let variant_stream = std::pin::pin!(crate::stream::take(variant_stream, 2048));
|
||||||
|
let mut variant_stream = variant_stream.into_streamer();
|
||||||
|
|
||||||
while let Some(res) = variant_stream.next().await {
|
while let Some(res) = variant_stream.next().await {
|
||||||
metrics::counter!("pict-rs.cleanup.outdated-variant").increment(1);
|
metrics::counter!("pict-rs.cleanup.outdated-variant").increment(1);
|
||||||
|
@ -176,7 +178,9 @@ async fn outdated_proxies(repo: &ArcRepo, config: &Configuration) -> Result<(),
|
||||||
let now = time::OffsetDateTime::now_utc();
|
let now = time::OffsetDateTime::now_utc();
|
||||||
let since = now.saturating_sub(config.media.retention.proxy.to_duration());
|
let since = now.saturating_sub(config.media.retention.proxy.to_duration());
|
||||||
|
|
||||||
let mut alias_stream = repo.older_aliases(since).await?.into_streamer();
|
let alias_stream = repo.older_aliases(since).await?;
|
||||||
|
let alias_stream = std::pin::pin!(crate::stream::take(alias_stream, 2048));
|
||||||
|
let mut alias_stream = alias_stream.into_streamer();
|
||||||
|
|
||||||
while let Some(res) = alias_stream.next().await {
|
while let Some(res) = alias_stream.next().await {
|
||||||
metrics::counter!("pict-rs.cleanup.outdated-proxy").increment(1);
|
metrics::counter!("pict-rs.cleanup.outdated-proxy").increment(1);
|
||||||
|
|
|
@ -5,6 +5,35 @@ use streem::IntoStreamer;
|
||||||
|
|
||||||
use crate::future::WithMetrics;
|
use crate::future::WithMetrics;
|
||||||
|
|
||||||
|
pub(crate) fn take<S>(stream: S, amount: usize) -> 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();
|
||||||
|
|
||||||
|
let mut count = 0;
|
||||||
|
|
||||||
|
if count == amount {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
while let Some(item) = streamer.next().await {
|
||||||
|
tracing::trace!("take: looping");
|
||||||
|
|
||||||
|
yielder.yield_(item).await;
|
||||||
|
|
||||||
|
count += 1;
|
||||||
|
|
||||||
|
if count == amount {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
pub(crate) fn metrics<S>(name: &'static str, stream: S) -> impl Stream<Item = S::Item>
|
pub(crate) fn metrics<S>(name: &'static str, stream: S) -> impl Stream<Item = S::Item>
|
||||||
where
|
where
|
||||||
S: Stream,
|
S: Stream,
|
||||||
|
|
Loading…
Reference in a new issue