Skip to main content

TasksServiceClient

Struct TasksServiceClient 

Source
pub struct TasksServiceClient<T> { /* private fields */ }
Expand description

Orchestrator-hosted service that workers connect to for receiving tasks.

This service runs on the orchestrator (or any stateless dispatcher with access to the task queue). Workers are clients of this service — they call PullTasks to receive work.

Static worker configuration (blob service URL, blobification threshold, etc.) is provided via environment variables at deployment time. Only per-task information (e.g., the run-owning orchestrator URL) is sent in-band via TaskContext.

Workers report task completion via OrchestratorService.CompleteTask, which must reach the orchestrator that owns the specific run (URL provided per-task in TaskContext).

gRPC only — not exposed as REST.

Implementations§

Source§

impl TasksServiceClient<Channel>

Source

pub async fn connect<D>(dst: D) -> Result<Self, Error>
where D: TryInto<Endpoint>, D::Error: Into<StdError>,

Attempt to create a new client by connecting to a given endpoint.

Source§

impl<T> TasksServiceClient<T>
where T: GrpcService<Body>, T::Error: Into<StdError>, T::ResponseBody: Body<Data = Bytes> + Send + 'static, <T::ResponseBody as Body>::Error: Into<StdError> + Send,

Source

pub fn new(inner: T) -> Self

Source

pub fn with_origin(inner: T, origin: Uri) -> Self

Source

pub fn with_interceptor<F>( inner: T, interceptor: F, ) -> TasksServiceClient<InterceptedService<T, F>>
where F: Interceptor, T::ResponseBody: Default, T: Service<Request<Body>, Response = Response<<T as GrpcService<Body>>::ResponseBody>>, <T as Service<Request<Body>>>::Error: Into<StdError> + Send + Sync,

Source

pub fn send_compressed(self, encoding: CompressionEncoding) -> Self

Compress requests with the given encoding.

This requires the server to support it otherwise it might respond with an error.

Source

pub fn accept_compressed(self, encoding: CompressionEncoding) -> Self

Enable decompressing responses.

Source

pub fn max_decoding_message_size(self, limit: usize) -> Self

Limits the maximum size of a decoded message.

Default: 4MB

Source

pub fn max_encoding_message_size(self, limit: usize) -> Self

Limits the maximum size of an encoded message.

Default: usize::MAX

Source

pub async fn pull_tasks( &mut self, request: impl IntoRequest<PullTasksRequest>, ) -> Result<Response<Streaming<TaskAssignment>>, Status>

Pull task assignments for a specific plugin.

The worker specifies which plugin entry it is pulling for (by name from the orchestrator’s config). The orchestrator validates that the plugin uses a compatible transport (e.g., “pull”). If the plugin uses a queue-based transport (e.g., NATS, Kafka), this RPC returns FAILED_PRECONDITION.

The worker declares its concurrency limit. The stream stays open for the worker’s lifetime — tasks are sent as they become available.

Source

pub async fn get_orchestrator_for_run( &mut self, request: impl IntoRequest<GetOrchestratorForRunRequest>, ) -> Result<Response<GetOrchestratorForRunResponse>, Status>

Look up the current orchestrator for a run.

Workers call this when they cannot reach the orchestrator URL from their TaskContext (e.g., after an orchestrator restart or run migration). Any orchestrator can answer this — it performs a stateless lease lookup.

Returns the gRPC service URL of the orchestrator that currently owns the run, or NOT_FOUND if no active lease exists.

Trait Implementations§

Source§

impl<T: Clone> Clone for TasksServiceClient<T>

Source§

fn clone(&self) -> TasksServiceClient<T>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T: Debug> Debug for TasksServiceClient<T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<T> !Freeze for TasksServiceClient<T>

§

impl<T> RefUnwindSafe for TasksServiceClient<T>
where T: RefUnwindSafe,

§

impl<T> Send for TasksServiceClient<T>
where T: Send,

§

impl<T> Sync for TasksServiceClient<T>
where T: Sync,

§

impl<T> Unpin for TasksServiceClient<T>
where T: Unpin,

§

impl<T> UnsafeUnpin for TasksServiceClient<T>
where T: UnsafeUnpin,

§

impl<T> UnwindSafe for TasksServiceClient<T>
where T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FromRef<T> for T
where T: Clone,

Source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<L> LayerExt<L> for L

Source§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in Layered.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more