feat(tvix/castore): instrument tokio task with current span
By default tokio::spawn does not instrument the spawned task with the current spawn (https://github.com/tokio-rs/tokio/discussions/6008), do this manually for all tokio::spawn functions in functions that are instrumented. Change-Id: I83dd8145b3a62421454aff57d34180cebbee8304 Reviewed-on: https://cl.tvl.fyi/c/depot/+/11864 Tested-by: BuildkiteCI Reviewed-by: flokli <flokli@flokli.de> Autosubmit: Simon Hauser <simon.hauser@helsinki-systems.de>
This commit is contained in:
parent
bd8d74a3ee
commit
2b20d8d82d
3 changed files with 27 additions and 18 deletions
|
@ -18,7 +18,7 @@ use tokio_util::{
|
||||||
sync::PollSender,
|
sync::PollSender,
|
||||||
};
|
};
|
||||||
use tonic::{async_trait, transport::Channel, Code, Status};
|
use tonic::{async_trait, transport::Channel, Code, Status};
|
||||||
use tracing::instrument;
|
use tracing::{instrument, Instrument as _};
|
||||||
|
|
||||||
/// Connects to a (remote) tvix-store BlobService over gRPC.
|
/// Connects to a (remote) tvix-store BlobService over gRPC.
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
|
@ -133,6 +133,8 @@ impl BlobService for GRPCBlobService {
|
||||||
let task = tokio::spawn({
|
let task = tokio::spawn({
|
||||||
let mut grpc_client = self.grpc_client.clone();
|
let mut grpc_client = self.grpc_client.clone();
|
||||||
async move { Ok::<_, Status>(grpc_client.put(blobchunk_stream).await?.into_inner()) }
|
async move { Ok::<_, Status>(grpc_client.put(blobchunk_stream).await?.into_inner()) }
|
||||||
|
// instrument the task with the current span, this is not done by default
|
||||||
|
.in_current_span()
|
||||||
});
|
});
|
||||||
|
|
||||||
// The tx part of the channel is converted to a sink of byte chunks.
|
// The tx part of the channel is converted to a sink of byte chunks.
|
||||||
|
|
|
@ -12,7 +12,7 @@ use tokio_stream::wrappers::UnboundedReceiverStream;
|
||||||
use tonic::async_trait;
|
use tonic::async_trait;
|
||||||
use tonic::Code;
|
use tonic::Code;
|
||||||
use tonic::{transport::Channel, Status};
|
use tonic::{transport::Channel, Status};
|
||||||
use tracing::{instrument, warn};
|
use tracing::{instrument, warn, Instrument as _};
|
||||||
|
|
||||||
/// Connects to a (remote) tvix-store DirectoryService over gRPC.
|
/// Connects to a (remote) tvix-store DirectoryService over gRPC.
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
|
@ -194,14 +194,17 @@ impl DirectoryService for GRPCDirectoryService {
|
||||||
|
|
||||||
let (tx, rx) = tokio::sync::mpsc::unbounded_channel();
|
let (tx, rx) = tokio::sync::mpsc::unbounded_channel();
|
||||||
|
|
||||||
let task: JoinHandle<Result<proto::PutDirectoryResponse, Status>> = spawn(async move {
|
let task: JoinHandle<Result<proto::PutDirectoryResponse, Status>> = spawn(
|
||||||
let s = grpc_client
|
async move {
|
||||||
.put(UnboundedReceiverStream::new(rx))
|
let s = grpc_client
|
||||||
.await?
|
.put(UnboundedReceiverStream::new(rx))
|
||||||
.into_inner();
|
.await?
|
||||||
|
.into_inner();
|
||||||
|
|
||||||
Ok(s)
|
Ok(s)
|
||||||
});
|
} // instrument the task with the current span, this is not done by default
|
||||||
|
.in_current_span(),
|
||||||
|
);
|
||||||
|
|
||||||
Box::new(GRPCPutter {
|
Box::new(GRPCPutter {
|
||||||
rq: Some((task, tx)),
|
rq: Some((task, tx)),
|
||||||
|
|
|
@ -43,7 +43,7 @@ use tokio::{
|
||||||
io::{AsyncReadExt, AsyncSeekExt},
|
io::{AsyncReadExt, AsyncSeekExt},
|
||||||
sync::mpsc,
|
sync::mpsc,
|
||||||
};
|
};
|
||||||
use tracing::{debug, error, instrument, warn, Span};
|
use tracing::{debug, error, instrument, warn, Instrument as _, Span};
|
||||||
|
|
||||||
/// This implements a read-only FUSE filesystem for a tvix-store
|
/// This implements a read-only FUSE filesystem for a tvix-store
|
||||||
/// with the passed [BlobService], [DirectoryService] and [RootNodes].
|
/// with the passed [BlobService], [DirectoryService] and [RootNodes].
|
||||||
|
@ -397,16 +397,20 @@ where
|
||||||
|
|
||||||
// This task will run in the background immediately and will exit
|
// This task will run in the background immediately and will exit
|
||||||
// after the stream ends or if we no longer want any more entries.
|
// after the stream ends or if we no longer want any more entries.
|
||||||
self.tokio_handle.spawn(async move {
|
self.tokio_handle.spawn(
|
||||||
let mut stream = root_nodes_provider.list().enumerate();
|
async move {
|
||||||
while let Some(node) = stream.next().await {
|
let mut stream = root_nodes_provider.list().enumerate();
|
||||||
if tx.send(node).await.is_err() {
|
while let Some(node) = stream.next().await {
|
||||||
// If we get a send error, it means the sync code
|
if tx.send(node).await.is_err() {
|
||||||
// doesn't want any more entries.
|
// If we get a send error, it means the sync code
|
||||||
break;
|
// doesn't want any more entries.
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
// instrument the task with the current span, this is not done by default
|
||||||
|
.in_current_span(),
|
||||||
|
);
|
||||||
|
|
||||||
// Put the rx part into [self.dir_handles].
|
// Put the rx part into [self.dir_handles].
|
||||||
// TODO: this will overflow after 2**64 operations,
|
// TODO: this will overflow after 2**64 operations,
|
||||||
|
|
Loading…
Reference in a new issue