mirror of
https://git.asonix.dog/asonix/pict-rs
synced 2025-01-05 01:01:24 +00:00
Replace most of actix-rt with tokio, give names to tasks
This commit is contained in:
parent
c8b61da66b
commit
c795c1edfa
18 changed files with 105 additions and 65 deletions
|
@ -83,6 +83,7 @@ impl Drop for Backgrounded {
|
||||||
let cleanup_span = tracing::info_span!(parent: &cleanup_parent_span, "Backgrounded cleanup Identifier", identifier = ?identifier);
|
let cleanup_span = tracing::info_span!(parent: &cleanup_parent_span, "Backgrounded cleanup Identifier", identifier = ?identifier);
|
||||||
|
|
||||||
crate::sync::spawn(
|
crate::sync::spawn(
|
||||||
|
"backgrounded-cleanup-identifier",
|
||||||
async move {
|
async move {
|
||||||
let _ = crate::queue::cleanup_identifier(&repo, &identifier).await;
|
let _ = crate::queue::cleanup_identifier(&repo, &identifier).await;
|
||||||
}
|
}
|
||||||
|
@ -96,6 +97,7 @@ impl Drop for Backgrounded {
|
||||||
let cleanup_span = tracing::info_span!(parent: &cleanup_parent_span, "Backgrounded cleanup Upload ID", upload_id = ?upload_id);
|
let cleanup_span = tracing::info_span!(parent: &cleanup_parent_span, "Backgrounded cleanup Upload ID", upload_id = ?upload_id);
|
||||||
|
|
||||||
crate::sync::spawn(
|
crate::sync::spawn(
|
||||||
|
"backgrounded-claim-upload",
|
||||||
async move {
|
async move {
|
||||||
let _ = repo.claim(upload_id).await;
|
let _ = repo.claim(upload_id).await;
|
||||||
}
|
}
|
||||||
|
|
|
@ -381,7 +381,7 @@ mod io_uring {
|
||||||
macro_rules! test_async {
|
macro_rules! test_async {
|
||||||
($fut:expr) => {
|
($fut:expr) => {
|
||||||
actix_web::rt::System::new()
|
actix_web::rt::System::new()
|
||||||
.block_on(async move { crate::sync::spawn($fut).await.unwrap() })
|
.block_on(async move { crate::sync::spawn("tests", $fut).await.unwrap() })
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,11 +35,11 @@ pub(crate) trait NowOrNever: Future {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) trait WithTimeout: Future {
|
pub(crate) trait WithTimeout: Future {
|
||||||
fn with_timeout(self, duration: Duration) -> actix_web::rt::time::Timeout<Self>
|
fn with_timeout(self, duration: Duration) -> tokio::time::Timeout<Self>
|
||||||
where
|
where
|
||||||
Self: Sized,
|
Self: Sized,
|
||||||
{
|
{
|
||||||
actix_web::rt::time::timeout(duration, self)
|
tokio::time::timeout(duration, self)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -248,6 +248,7 @@ impl Drop for Session {
|
||||||
let cleanup_span = tracing::info_span!(parent: &cleanup_parent_span, "Session cleanup hash", hash = ?hash);
|
let cleanup_span = tracing::info_span!(parent: &cleanup_parent_span, "Session cleanup hash", hash = ?hash);
|
||||||
|
|
||||||
crate::sync::spawn(
|
crate::sync::spawn(
|
||||||
|
"session-cleanup-hash",
|
||||||
async move {
|
async move {
|
||||||
let _ = crate::queue::cleanup_hash(&repo, hash).await;
|
let _ = crate::queue::cleanup_hash(&repo, hash).await;
|
||||||
}
|
}
|
||||||
|
@ -262,6 +263,7 @@ impl Drop for Session {
|
||||||
let cleanup_span = tracing::info_span!(parent: &cleanup_parent_span, "Session cleanup alias", alias = ?alias);
|
let cleanup_span = tracing::info_span!(parent: &cleanup_parent_span, "Session cleanup alias", alias = ?alias);
|
||||||
|
|
||||||
crate::sync::spawn(
|
crate::sync::spawn(
|
||||||
|
"session-cleanup-alias",
|
||||||
async move {
|
async move {
|
||||||
let _ = crate::queue::cleanup_alias(&repo, alias, token).await;
|
let _ = crate::queue::cleanup_alias(&repo, alias, token).await;
|
||||||
}
|
}
|
||||||
|
@ -275,6 +277,7 @@ impl Drop for Session {
|
||||||
let cleanup_span = tracing::info_span!(parent: &cleanup_parent_span, "Session cleanup identifier", identifier = ?identifier);
|
let cleanup_span = tracing::info_span!(parent: &cleanup_parent_span, "Session cleanup identifier", identifier = ?identifier);
|
||||||
|
|
||||||
crate::sync::spawn(
|
crate::sync::spawn(
|
||||||
|
"session-cleanup-identifier",
|
||||||
async move {
|
async move {
|
||||||
let _ = crate::queue::cleanup_identifier(&repo, &identifier).await;
|
let _ = crate::queue::cleanup_identifier(&repo, &identifier).await;
|
||||||
}
|
}
|
||||||
|
|
|
@ -80,7 +80,7 @@ mod test {
|
||||||
macro_rules! test_async {
|
macro_rules! test_async {
|
||||||
($fut:expr) => {
|
($fut:expr) => {
|
||||||
actix_web::rt::System::new()
|
actix_web::rt::System::new()
|
||||||
.block_on(async move { crate::sync::spawn($fut).await.unwrap() })
|
.block_on(async move { crate::sync::spawn("tests", $fut).await.unwrap() })
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
25
src/lib.rs
25
src/lib.rs
|
@ -1772,8 +1772,8 @@ fn spawn_cleanup(repo: ArcRepo, config: &Configuration) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
crate::sync::spawn(async move {
|
crate::sync::spawn("queue-cleanup", async move {
|
||||||
let mut interval = actix_web::rt::time::interval(Duration::from_secs(30));
|
let mut interval = tokio::time::interval(Duration::from_secs(30));
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
interval.tick().await;
|
interval.tick().await;
|
||||||
|
@ -1805,19 +1805,14 @@ fn spawn_workers<S>(
|
||||||
) where
|
) where
|
||||||
S: Store + 'static,
|
S: Store + 'static,
|
||||||
{
|
{
|
||||||
crate::sync::spawn(queue::process_cleanup(
|
crate::sync::spawn(
|
||||||
repo.clone(),
|
"cleanup-worker",
|
||||||
store.clone(),
|
queue::process_cleanup(repo.clone(), store.clone(), config.clone()),
|
||||||
config.clone(),
|
);
|
||||||
));
|
crate::sync::spawn(
|
||||||
crate::sync::spawn(queue::process_images(
|
"process-worker",
|
||||||
tmp_dir,
|
queue::process_images(tmp_dir, repo, store, client, process_map, config),
|
||||||
repo,
|
);
|
||||||
store,
|
|
||||||
client,
|
|
||||||
process_map,
|
|
||||||
config,
|
|
||||||
));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn launch_file_store<F: Fn(&mut web::ServiceConfig) + Send + Clone + 'static>(
|
async fn launch_file_store<F: Fn(&mut web::ServiceConfig) + Send + Clone + 'static>(
|
||||||
|
|
|
@ -47,7 +47,7 @@ async fn drain(rx: flume::Receiver<actix_web::dev::Payload>) {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
struct DrainHandle(Option<Rc<actix_web::rt::task::JoinHandle<()>>>);
|
struct DrainHandle(Option<Rc<tokio::task::JoinHandle<()>>>);
|
||||||
|
|
||||||
pub(crate) struct Payload {
|
pub(crate) struct Payload {
|
||||||
sender: flume::Sender<actix_web::dev::Payload>,
|
sender: flume::Sender<actix_web::dev::Payload>,
|
||||||
|
@ -65,7 +65,7 @@ pub(crate) struct PayloadStream {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl DrainHandle {
|
impl DrainHandle {
|
||||||
fn new(handle: actix_web::rt::task::JoinHandle<()>) -> Self {
|
fn new(handle: tokio::task::JoinHandle<()>) -> Self {
|
||||||
Self(Some(Rc::new(handle)))
|
Self(Some(Rc::new(handle)))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -74,7 +74,7 @@ impl Payload {
|
||||||
pub(crate) fn new() -> Self {
|
pub(crate) fn new() -> Self {
|
||||||
let (tx, rx) = crate::sync::channel(LIMIT);
|
let (tx, rx) = crate::sync::channel(LIMIT);
|
||||||
|
|
||||||
let handle = DrainHandle::new(crate::sync::spawn(drain(rx)));
|
let handle = DrainHandle::new(crate::sync::spawn("drain-payloads", drain(rx)));
|
||||||
|
|
||||||
Payload { sender: tx, handle }
|
Payload { sender: tx, handle }
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,7 +67,7 @@ where
|
||||||
tracing::warn!("Retrying migration +{failure_count}");
|
tracing::warn!("Retrying migration +{failure_count}");
|
||||||
}
|
}
|
||||||
|
|
||||||
actix_web::rt::time::sleep(Duration::from_secs(3)).await;
|
tokio::time::sleep(Duration::from_secs(3)).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
@ -398,7 +398,7 @@ where
|
||||||
tracing::warn!("Failed moving file. Retrying +{failure_count}");
|
tracing::warn!("Failed moving file. Retrying +{failure_count}");
|
||||||
}
|
}
|
||||||
|
|
||||||
actix_web::rt::time::sleep(Duration::from_secs(3)).await;
|
tokio::time::sleep(Duration::from_secs(3)).await;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
use actix_web::rt::task::JoinHandle;
|
|
||||||
use actix_web::web::Bytes;
|
use actix_web::web::Bytes;
|
||||||
use flume::r#async::RecvFut;
|
use flume::r#async::RecvFut;
|
||||||
use std::{
|
use std::{
|
||||||
|
@ -11,6 +10,7 @@ use std::{
|
||||||
use tokio::{
|
use tokio::{
|
||||||
io::{AsyncRead, AsyncWriteExt, ReadBuf},
|
io::{AsyncRead, AsyncWriteExt, ReadBuf},
|
||||||
process::{Child, ChildStdin, ChildStdout, Command},
|
process::{Child, ChildStdin, ChildStdout, Command},
|
||||||
|
task::JoinHandle,
|
||||||
};
|
};
|
||||||
use tracing::{Instrument, Span};
|
use tracing::{Instrument, Span};
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ pub(crate) struct ProcessRead<I> {
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
handle: DropHandle,
|
handle: DropHandle,
|
||||||
eof: bool,
|
eof: bool,
|
||||||
sleep: Pin<Box<actix_web::rt::time::Sleep>>,
|
sleep: Pin<Box<tokio::time::Sleep>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, thiserror::Error)]
|
#[derive(Debug, thiserror::Error)]
|
||||||
|
@ -213,6 +213,7 @@ impl Process {
|
||||||
span.follows_from(Span::current());
|
span.follows_from(Span::current());
|
||||||
|
|
||||||
let handle = crate::sync::spawn(
|
let handle = crate::sync::spawn(
|
||||||
|
"await-process",
|
||||||
async move {
|
async move {
|
||||||
let child_fut = async {
|
let child_fut = async {
|
||||||
(f)(stdin).await?;
|
(f)(stdin).await?;
|
||||||
|
@ -238,7 +239,7 @@ impl Process {
|
||||||
.instrument(span),
|
.instrument(span),
|
||||||
);
|
);
|
||||||
|
|
||||||
let sleep = actix_web::rt::time::sleep(timeout);
|
let sleep = tokio::time::sleep(timeout);
|
||||||
|
|
||||||
ProcessRead {
|
ProcessRead {
|
||||||
inner: stdout,
|
inner: stdout,
|
||||||
|
|
|
@ -203,7 +203,7 @@ async fn process_jobs<S, F>(
|
||||||
tracing::warn!("{}", format!("{e:?}"));
|
tracing::warn!("{}", format!("{e:?}"));
|
||||||
|
|
||||||
if e.is_disconnected() {
|
if e.is_disconnected() {
|
||||||
actix_web::rt::time::sleep(Duration::from_secs(10)).await;
|
tokio::time::sleep(Duration::from_secs(10)).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
|
@ -341,7 +341,7 @@ async fn process_image_jobs<S, F>(
|
||||||
tracing::warn!("{}", format!("{e:?}"));
|
tracing::warn!("{}", format!("{e:?}"));
|
||||||
|
|
||||||
if e.is_disconnected() {
|
if e.is_disconnected() {
|
||||||
actix_web::rt::time::sleep(Duration::from_secs(3)).await;
|
tokio::time::sleep(Duration::from_secs(3)).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
|
@ -423,7 +423,7 @@ where
|
||||||
let mut fut =
|
let mut fut =
|
||||||
std::pin::pin!(fut.instrument(tracing::info_span!("job-future", job_id = ?job_id)));
|
std::pin::pin!(fut.instrument(tracing::info_span!("job-future", job_id = ?job_id)));
|
||||||
|
|
||||||
let mut interval = actix_web::rt::time::interval(Duration::from_secs(5));
|
let mut interval = tokio::time::interval(Duration::from_secs(5));
|
||||||
|
|
||||||
let mut hb = None;
|
let mut hb = None;
|
||||||
|
|
||||||
|
|
|
@ -136,7 +136,7 @@ where
|
||||||
let client = client.clone();
|
let client = client.clone();
|
||||||
|
|
||||||
let media = media.clone();
|
let media = media.clone();
|
||||||
let error_boundary = crate::sync::spawn(async move {
|
let error_boundary = crate::sync::spawn("ingest-media", async move {
|
||||||
let stream = crate::stream::from_err(store2.to_stream(&ident, None, None).await?);
|
let stream = crate::stream::from_err(store2.to_stream(&ident, None, None).await?);
|
||||||
|
|
||||||
let session = crate::ingest::ingest(
|
let session = crate::ingest::ingest(
|
||||||
|
|
|
@ -49,7 +49,7 @@ use super::{
|
||||||
pub(crate) struct PostgresRepo {
|
pub(crate) struct PostgresRepo {
|
||||||
inner: Arc<Inner>,
|
inner: Arc<Inner>,
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
notifications: Arc<actix_web::rt::task::JoinHandle<()>>,
|
notifications: Arc<tokio::task::JoinHandle<()>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
struct Inner {
|
struct Inner {
|
||||||
|
@ -151,7 +151,7 @@ impl PostgresRepo {
|
||||||
.await
|
.await
|
||||||
.map_err(ConnectPostgresError::ConnectForMigration)?;
|
.map_err(ConnectPostgresError::ConnectForMigration)?;
|
||||||
|
|
||||||
let handle = crate::sync::spawn(conn);
|
let handle = crate::sync::spawn("postgres-migrations", conn);
|
||||||
|
|
||||||
embedded::migrations::runner()
|
embedded::migrations::runner()
|
||||||
.run_async(&mut client)
|
.run_async(&mut client)
|
||||||
|
@ -199,7 +199,10 @@ impl PostgresRepo {
|
||||||
upload_notifications: DashMap::new(),
|
upload_notifications: DashMap::new(),
|
||||||
});
|
});
|
||||||
|
|
||||||
let handle = crate::sync::spawn(delegate_notifications(rx, inner.clone(), parallelism * 8));
|
let handle = crate::sync::spawn(
|
||||||
|
"postgres-delegate-notifications",
|
||||||
|
delegate_notifications(rx, inner.clone(), parallelism * 8),
|
||||||
|
);
|
||||||
|
|
||||||
let notifications = Arc::new(handle);
|
let notifications = Arc::new(handle);
|
||||||
|
|
||||||
|
@ -411,7 +414,7 @@ fn spawn_db_notification_task(
|
||||||
sender: flume::Sender<Notification>,
|
sender: flume::Sender<Notification>,
|
||||||
mut conn: Connection<Socket, NoTlsStream>,
|
mut conn: Connection<Socket, NoTlsStream>,
|
||||||
) {
|
) {
|
||||||
crate::sync::spawn(async move {
|
crate::sync::spawn("postgres-notifications", async move {
|
||||||
while let Some(res) = std::future::poll_fn(|cx| conn.poll_message(cx)).await {
|
while let Some(res) = std::future::poll_fn(|cx| conn.poll_message(cx)).await {
|
||||||
match res {
|
match res {
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
|
|
|
@ -30,7 +30,7 @@ macro_rules! b {
|
||||||
($self:ident.$ident:ident, $expr:expr) => {{
|
($self:ident.$ident:ident, $expr:expr) => {{
|
||||||
let $ident = $self.$ident.clone();
|
let $ident = $self.$ident.clone();
|
||||||
|
|
||||||
crate::sync::spawn_blocking(move || $expr)
|
crate::sync::spawn_blocking("sled-io", move || $expr)
|
||||||
.await
|
.await
|
||||||
.map_err(SledError::from)
|
.map_err(SledError::from)
|
||||||
.map_err(RepoError::from)?
|
.map_err(RepoError::from)?
|
||||||
|
@ -174,7 +174,7 @@ impl SledRepo {
|
||||||
|
|
||||||
let this = self.db.clone();
|
let this = self.db.clone();
|
||||||
|
|
||||||
crate::sync::spawn_blocking(move || {
|
crate::sync::spawn_blocking("sled-io", move || {
|
||||||
let export = this.export();
|
let export = this.export();
|
||||||
export_db.import(export);
|
export_db.import(export);
|
||||||
})
|
})
|
||||||
|
@ -257,7 +257,7 @@ impl AliasAccessRepo for SledRepo {
|
||||||
let alias_access = self.alias_access.clone();
|
let alias_access = self.alias_access.clone();
|
||||||
let inverse_alias_access = self.inverse_alias_access.clone();
|
let inverse_alias_access = self.inverse_alias_access.clone();
|
||||||
|
|
||||||
let res = crate::sync::spawn_blocking(move || {
|
let res = crate::sync::spawn_blocking("sled-io", move || {
|
||||||
(&alias_access, &inverse_alias_access).transaction(
|
(&alias_access, &inverse_alias_access).transaction(
|
||||||
|(alias_access, inverse_alias_access)| {
|
|(alias_access, inverse_alias_access)| {
|
||||||
if let Some(old) = alias_access.insert(alias.to_bytes(), &value_bytes)? {
|
if let Some(old) = alias_access.insert(alias.to_bytes(), &value_bytes)? {
|
||||||
|
@ -323,7 +323,7 @@ impl AliasAccessRepo for SledRepo {
|
||||||
let alias_access = self.alias_access.clone();
|
let alias_access = self.alias_access.clone();
|
||||||
let inverse_alias_access = self.inverse_alias_access.clone();
|
let inverse_alias_access = self.inverse_alias_access.clone();
|
||||||
|
|
||||||
let res = crate::sync::spawn_blocking(move || {
|
let res = crate::sync::spawn_blocking("sled-io", move || {
|
||||||
(&alias_access, &inverse_alias_access).transaction(
|
(&alias_access, &inverse_alias_access).transaction(
|
||||||
|(alias_access, inverse_alias_access)| {
|
|(alias_access, inverse_alias_access)| {
|
||||||
if let Some(old) = alias_access.remove(alias.to_bytes())? {
|
if let Some(old) = alias_access.remove(alias.to_bytes())? {
|
||||||
|
@ -363,7 +363,7 @@ impl VariantAccessRepo for SledRepo {
|
||||||
let variant_access = self.variant_access.clone();
|
let variant_access = self.variant_access.clone();
|
||||||
let inverse_variant_access = self.inverse_variant_access.clone();
|
let inverse_variant_access = self.inverse_variant_access.clone();
|
||||||
|
|
||||||
let res = crate::sync::spawn_blocking(move || {
|
let res = crate::sync::spawn_blocking("sled-io", move || {
|
||||||
(&variant_access, &inverse_variant_access).transaction(
|
(&variant_access, &inverse_variant_access).transaction(
|
||||||
|(variant_access, inverse_variant_access)| {
|
|(variant_access, inverse_variant_access)| {
|
||||||
if let Some(old) = variant_access.insert(&key, &value_bytes)? {
|
if let Some(old) = variant_access.insert(&key, &value_bytes)? {
|
||||||
|
@ -433,7 +433,7 @@ impl VariantAccessRepo for SledRepo {
|
||||||
let variant_access = self.variant_access.clone();
|
let variant_access = self.variant_access.clone();
|
||||||
let inverse_variant_access = self.inverse_variant_access.clone();
|
let inverse_variant_access = self.inverse_variant_access.clone();
|
||||||
|
|
||||||
let res = crate::sync::spawn_blocking(move || {
|
let res = crate::sync::spawn_blocking("sled-io", move || {
|
||||||
(&variant_access, &inverse_variant_access).transaction(
|
(&variant_access, &inverse_variant_access).transaction(
|
||||||
|(variant_access, inverse_variant_access)| {
|
|(variant_access, inverse_variant_access)| {
|
||||||
if let Some(old) = variant_access.remove(&key)? {
|
if let Some(old) = variant_access.remove(&key)? {
|
||||||
|
@ -633,7 +633,7 @@ impl QueueRepo for SledRepo {
|
||||||
let queue = self.queue.clone();
|
let queue = self.queue.clone();
|
||||||
let job_state = self.job_state.clone();
|
let job_state = self.job_state.clone();
|
||||||
|
|
||||||
let res = crate::sync::spawn_blocking(move || {
|
let res = crate::sync::spawn_blocking("sled-io", move || {
|
||||||
(&queue, &job_state).transaction(|(queue, job_state)| {
|
(&queue, &job_state).transaction(|(queue, job_state)| {
|
||||||
let state = JobState::pending();
|
let state = JobState::pending();
|
||||||
|
|
||||||
|
@ -683,7 +683,7 @@ impl QueueRepo for SledRepo {
|
||||||
let job_state = self.job_state.clone();
|
let job_state = self.job_state.clone();
|
||||||
|
|
||||||
let span = tracing::Span::current();
|
let span = tracing::Span::current();
|
||||||
let opt = crate::sync::spawn_blocking(move || {
|
let opt = crate::sync::spawn_blocking("sled-io", move || {
|
||||||
let _guard = span.enter();
|
let _guard = span.enter();
|
||||||
// Job IDs are generated with Uuid version 7 - defining their first bits as a
|
// Job IDs are generated with Uuid version 7 - defining their first bits as a
|
||||||
// timestamp. Scanning a prefix should give us jobs in the order they were queued.
|
// timestamp. Scanning a prefix should give us jobs in the order they were queued.
|
||||||
|
@ -776,7 +776,7 @@ impl QueueRepo for SledRepo {
|
||||||
|
|
||||||
let job_state = self.job_state.clone();
|
let job_state = self.job_state.clone();
|
||||||
|
|
||||||
crate::sync::spawn_blocking(move || {
|
crate::sync::spawn_blocking("sled-io", move || {
|
||||||
if let Some(state) = job_state.get(&key)? {
|
if let Some(state) = job_state.get(&key)? {
|
||||||
let new_state = JobState::running(worker_id);
|
let new_state = JobState::running(worker_id);
|
||||||
|
|
||||||
|
@ -806,7 +806,7 @@ impl QueueRepo for SledRepo {
|
||||||
let queue = self.queue.clone();
|
let queue = self.queue.clone();
|
||||||
let job_state = self.job_state.clone();
|
let job_state = self.job_state.clone();
|
||||||
|
|
||||||
let res = crate::sync::spawn_blocking(move || {
|
let res = crate::sync::spawn_blocking("sled-io", move || {
|
||||||
(&queue, &job_state).transaction(|(queue, job_state)| {
|
(&queue, &job_state).transaction(|(queue, job_state)| {
|
||||||
queue.remove(&key[..])?;
|
queue.remove(&key[..])?;
|
||||||
job_state.remove(&key[..])?;
|
job_state.remove(&key[..])?;
|
||||||
|
@ -1065,7 +1065,7 @@ impl HashRepo for SledRepo {
|
||||||
None => (self.hashes_inverse.iter(), None),
|
None => (self.hashes_inverse.iter(), None),
|
||||||
};
|
};
|
||||||
|
|
||||||
crate::sync::spawn_blocking(move || {
|
crate::sync::spawn_blocking("sled-io", move || {
|
||||||
let page_iter = page_iter
|
let page_iter = page_iter
|
||||||
.keys()
|
.keys()
|
||||||
.rev()
|
.rev()
|
||||||
|
@ -1117,7 +1117,7 @@ impl HashRepo for SledRepo {
|
||||||
let page_iter = self.hashes_inverse.range(..=date_nanos);
|
let page_iter = self.hashes_inverse.range(..=date_nanos);
|
||||||
let prev_iter = Some(self.hashes_inverse.range(date_nanos..));
|
let prev_iter = Some(self.hashes_inverse.range(date_nanos..));
|
||||||
|
|
||||||
crate::sync::spawn_blocking(move || {
|
crate::sync::spawn_blocking("sled-io", move || {
|
||||||
let page_iter = page_iter
|
let page_iter = page_iter
|
||||||
.keys()
|
.keys()
|
||||||
.rev()
|
.rev()
|
||||||
|
@ -1245,7 +1245,7 @@ impl HashRepo for SledRepo {
|
||||||
|
|
||||||
let hash_variant_identifiers = self.hash_variant_identifiers.clone();
|
let hash_variant_identifiers = self.hash_variant_identifiers.clone();
|
||||||
|
|
||||||
crate::sync::spawn_blocking(move || {
|
crate::sync::spawn_blocking("sled-io", move || {
|
||||||
hash_variant_identifiers
|
hash_variant_identifiers
|
||||||
.compare_and_swap(key, Option::<&[u8]>::None, Some(value.as_bytes()))
|
.compare_and_swap(key, Option::<&[u8]>::None, Some(value.as_bytes()))
|
||||||
.map(|res| res.map_err(|_| VariantAlreadyExists))
|
.map(|res| res.map_err(|_| VariantAlreadyExists))
|
||||||
|
@ -1537,8 +1537,8 @@ impl std::fmt::Debug for SledRepo {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<actix_web::rt::task::JoinError> for SledError {
|
impl From<tokio::task::JoinError> for SledError {
|
||||||
fn from(_: actix_web::rt::task::JoinError) -> Self {
|
fn from(_: tokio::task::JoinError) -> Self {
|
||||||
SledError::Panic
|
SledError::Panic
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,7 +34,7 @@ macro_rules! b {
|
||||||
($self:ident.$ident:ident, $expr:expr) => {{
|
($self:ident.$ident:ident, $expr:expr) => {{
|
||||||
let $ident = $self.$ident.clone();
|
let $ident = $self.$ident.clone();
|
||||||
|
|
||||||
crate::sync::spawn_blocking(move || $expr)
|
crate::sync::spawn_blocking("04-sled-io", move || $expr)
|
||||||
.await
|
.await
|
||||||
.map_err(SledError::from)
|
.map_err(SledError::from)
|
||||||
.map_err(RepoError::from)?
|
.map_err(RepoError::from)?
|
||||||
|
@ -313,8 +313,8 @@ impl std::fmt::Debug for SledRepo {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<actix_web::rt::task::JoinError> for SledError {
|
impl From<tokio::task::JoinError> for SledError {
|
||||||
fn from(_: actix_web::rt::task::JoinError) -> Self {
|
fn from(_: tokio::task::JoinError) -> Self {
|
||||||
SledError::Panic
|
SledError::Panic
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -274,6 +274,7 @@ impl Store for ObjectStore {
|
||||||
let object_id2 = object_id.clone();
|
let object_id2 = object_id.clone();
|
||||||
let upload_id2 = upload_id.to_string();
|
let upload_id2 = upload_id.to_string();
|
||||||
let handle = crate::sync::spawn(
|
let handle = crate::sync::spawn(
|
||||||
|
"upload-multipart-part",
|
||||||
async move {
|
async move {
|
||||||
let response = this
|
let response = this
|
||||||
.create_upload_part_request(
|
.create_upload_part_request(
|
||||||
|
|
|
@ -30,7 +30,7 @@ where
|
||||||
{
|
{
|
||||||
let (tx, rx) = crate::sync::channel(1);
|
let (tx, rx) = crate::sync::channel(1);
|
||||||
|
|
||||||
let handle = crate::sync::spawn(async move {
|
let handle = crate::sync::spawn("send-stream", async move {
|
||||||
let stream = std::pin::pin!(stream);
|
let stream = std::pin::pin!(stream);
|
||||||
let mut streamer = stream.into_streamer();
|
let mut streamer = stream.into_streamer();
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ where
|
||||||
{
|
{
|
||||||
let (tx, rx) = crate::sync::channel(buffer);
|
let (tx, rx) = crate::sync::channel(buffer);
|
||||||
|
|
||||||
let handle = crate::sync::spawn_blocking(move || {
|
let handle = crate::sync::spawn_blocking("blocking-iterator", move || {
|
||||||
for value in iterator {
|
for value in iterator {
|
||||||
if tx.send(value).is_err() {
|
if tx.send(value).is_err() {
|
||||||
break;
|
break;
|
||||||
|
@ -148,7 +148,7 @@ where
|
||||||
S::Item: 'static,
|
S::Item: 'static,
|
||||||
{
|
{
|
||||||
streem::try_from_fn(|yielder| async move {
|
streem::try_from_fn(|yielder| async move {
|
||||||
actix_web::rt::time::timeout(duration, async move {
|
tokio::time::timeout(duration, async move {
|
||||||
let stream = std::pin::pin!(stream);
|
let stream = std::pin::pin!(stream);
|
||||||
let mut streamer = stream.into_streamer();
|
let mut streamer = stream.into_streamer();
|
||||||
|
|
||||||
|
|
51
src/sync.rs
51
src/sync.rs
|
@ -4,7 +4,13 @@ use tokio::sync::{Notify, Semaphore};
|
||||||
|
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
pub(crate) fn channel<T>(bound: usize) -> (flume::Sender<T>, flume::Receiver<T>) {
|
pub(crate) fn channel<T>(bound: usize) -> (flume::Sender<T>, flume::Receiver<T>) {
|
||||||
tracing::trace_span!(parent: None, "make channel").in_scope(|| flume::bounded(bound))
|
let span = tracing::trace_span!(parent: None, "make channel");
|
||||||
|
let guard = span.enter();
|
||||||
|
|
||||||
|
let channel = flume::bounded(bound);
|
||||||
|
|
||||||
|
drop(guard);
|
||||||
|
channel
|
||||||
}
|
}
|
||||||
|
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
|
@ -14,31 +20,60 @@ pub(crate) fn notify() -> Arc<Notify> {
|
||||||
|
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
pub(crate) fn bare_notify() -> Notify {
|
pub(crate) fn bare_notify() -> Notify {
|
||||||
tracing::trace_span!(parent: None, "make notifier").in_scope(Notify::new)
|
let span = tracing::trace_span!(parent: None, "make notifier");
|
||||||
|
let guard = span.enter();
|
||||||
|
|
||||||
|
let notify = Notify::new();
|
||||||
|
|
||||||
|
drop(guard);
|
||||||
|
notify
|
||||||
}
|
}
|
||||||
|
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
pub(crate) fn bare_semaphore(permits: usize) -> Semaphore {
|
pub(crate) fn bare_semaphore(permits: usize) -> Semaphore {
|
||||||
tracing::trace_span!(parent: None, "make semaphore").in_scope(|| Semaphore::new(permits))
|
let span = tracing::trace_span!(parent: None, "make semaphore");
|
||||||
|
let guard = span.enter();
|
||||||
|
|
||||||
|
let semaphore = Semaphore::new(permits);
|
||||||
|
|
||||||
|
drop(guard);
|
||||||
|
semaphore
|
||||||
}
|
}
|
||||||
|
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
pub(crate) fn spawn<F>(future: F) -> actix_web::rt::task::JoinHandle<F::Output>
|
pub(crate) fn spawn<F>(name: &str, future: F) -> tokio::task::JoinHandle<F::Output>
|
||||||
where
|
where
|
||||||
F: std::future::Future + 'static,
|
F: std::future::Future + 'static,
|
||||||
F::Output: 'static,
|
F::Output: 'static,
|
||||||
{
|
{
|
||||||
tracing::trace_span!(parent: None, "spawn task").in_scope(|| actix_web::rt::spawn(future))
|
let span = tracing::trace_span!(parent: None, "spawn task");
|
||||||
|
let guard = span.enter();
|
||||||
|
|
||||||
|
let handle = tokio::task::Builder::new()
|
||||||
|
.name(name)
|
||||||
|
.spawn_local(future)
|
||||||
|
.expect("Failed to spawn");
|
||||||
|
|
||||||
|
drop(guard);
|
||||||
|
handle
|
||||||
}
|
}
|
||||||
|
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
pub(crate) fn spawn_blocking<F, Out>(function: F) -> actix_web::rt::task::JoinHandle<Out>
|
pub(crate) fn spawn_blocking<F, Out>(name: &str, function: F) -> tokio::task::JoinHandle<Out>
|
||||||
where
|
where
|
||||||
F: FnOnce() -> Out + Send + 'static,
|
F: FnOnce() -> Out + Send + 'static,
|
||||||
Out: Send + 'static,
|
Out: Send + 'static,
|
||||||
{
|
{
|
||||||
let outer_span = tracing::Span::current();
|
let outer_span = tracing::Span::current();
|
||||||
|
|
||||||
tracing::trace_span!(parent: None, "spawn blocking task")
|
let span = tracing::trace_span!(parent: None, "spawn blocking task");
|
||||||
.in_scope(|| actix_web::rt::task::spawn_blocking(move || outer_span.in_scope(function)))
|
let guard = span.enter();
|
||||||
|
|
||||||
|
let handle = tokio::task::Builder::new()
|
||||||
|
.name(name)
|
||||||
|
.spawn_blocking(move || outer_span.in_scope(function))
|
||||||
|
.expect("Failed to spawn");
|
||||||
|
|
||||||
|
drop(guard);
|
||||||
|
handle
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,7 +51,7 @@ struct TmpFile(PathBuf);
|
||||||
|
|
||||||
impl Drop for TmpFile {
|
impl Drop for TmpFile {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
crate::sync::spawn(tokio::fs::remove_file(self.0.clone()));
|
crate::sync::spawn("remove-tmpfile", tokio::fs::remove_file(self.0.clone()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue