text-generation-inference/router/client/src/client.rs

98 lines
3.5 KiB
Rust
Raw Normal View History

2022-10-18 13:19:03 +00:00
/// Single shard Client
use crate::pb::generate::v1::text_generation_service_client::TextGenerationServiceClient;
2022-10-08 10:30:12 +00:00
use crate::pb::generate::v1::*;
use crate::Result;
2023-02-13 12:02:45 +00:00
use grpc_metadata::InjectTelemetryContext;
2022-10-08 10:30:12 +00:00
use tonic::transport::{Channel, Uri};
2023-02-13 12:02:45 +00:00
use tracing::instrument;
2022-10-08 10:30:12 +00:00
2022-10-18 13:19:03 +00:00
/// Text Generation Inference gRPC client
2022-10-08 10:30:12 +00:00
#[derive(Clone)]
pub struct Client {
2022-10-17 12:59:00 +00:00
stub: TextGenerationServiceClient<Channel>,
2022-10-08 10:30:12 +00:00
}
impl Client {
2022-10-17 12:59:00 +00:00
/// Returns a client connected to the given url
pub async fn connect(uri: Uri) -> Result<Self> {
let channel = Channel::builder(uri).connect().await?;
2022-10-08 10:30:12 +00:00
2022-10-17 12:59:00 +00:00
Ok(Self {
stub: TextGenerationServiceClient::new(channel),
})
2022-10-08 10:30:12 +00:00
}
2022-10-17 12:59:00 +00:00
/// Returns a client connected to the given unix socket
pub async fn connect_uds(path: String) -> Result<Self> {
let channel = Channel::from_shared("http://[::]:50051".to_string())
2022-10-08 10:30:12 +00:00
.unwrap()
.connect_with_connector(tower::service_fn(move |_: Uri| {
tokio::net::UnixStream::connect(path.clone())
}))
2022-10-17 12:59:00 +00:00
.await?;
2022-10-08 10:30:12 +00:00
2022-10-17 12:59:00 +00:00
Ok(Self {
stub: TextGenerationServiceClient::new(channel),
})
2022-10-08 10:30:12 +00:00
}
2022-10-18 13:19:03 +00:00
/// Returns a list of uris or unix sockets of all shards
2022-10-08 10:30:12 +00:00
#[instrument(skip(self))]
pub async fn service_discovery(&mut self) -> Result<Vec<String>> {
2023-02-13 12:02:45 +00:00
let request = tonic::Request::new(ServiceDiscoveryRequest {}).inject_context();
let response = self.stub.service_discovery(request).await?;
2022-10-08 10:30:12 +00:00
let urls = response
.into_inner()
.urls
.into_iter()
2022-10-18 13:19:03 +00:00
// Remove unix socket prefix
2022-10-08 10:30:12 +00:00
.map(|url| match url.strip_prefix("unix://") {
None => url,
Some(stripped_url) => stripped_url.to_string(),
})
.collect();
Ok(urls)
}
/// Get model info
#[instrument(skip(self))]
pub async fn info(&mut self) -> Result<InfoResponse> {
let request = tonic::Request::new(InfoRequest {}).inject_context();
let response = self.stub.info(request).await?.into_inner();
Ok(response)
}
2022-10-18 13:19:03 +00:00
/// Clear the past generations cache
2022-10-08 10:30:12 +00:00
#[instrument(skip(self))]
pub async fn clear_cache(&mut self, batch_id: Option<u64>) -> Result<()> {
let request = tonic::Request::new(ClearCacheRequest { id: batch_id }).inject_context();
2023-02-13 12:02:45 +00:00
self.stub.clear_cache(request).await?;
2022-10-08 10:30:12 +00:00
Ok(())
}
2022-10-18 13:19:03 +00:00
/// Generate one token for each request in the given batch
///
/// Returns Generation for each request in batch
2022-10-18 13:19:03 +00:00
/// and the next cached batch
2023-02-13 12:02:45 +00:00
#[instrument(skip_all, fields(id = &batch.id, size = &batch.size))]
pub async fn prefill(&mut self, batch: Batch) -> Result<(Vec<Generation>, Option<Batch>)> {
2023-02-13 12:02:45 +00:00
let request = tonic::Request::new(PrefillRequest { batch: Some(batch) }).inject_context();
let response = self.stub.prefill(request).await?.into_inner();
Ok((response.generations, response.batch))
2022-10-08 10:30:12 +00:00
}
/// Generate one token for each request in the given cached batches
2022-10-18 13:19:03 +00:00
///
/// Returns Generation for each request in batches
2022-10-18 13:19:03 +00:00
/// and the next cached batch
2023-02-13 12:02:45 +00:00
#[instrument(skip_all, fields(size = batches.iter().map(|batch|{batch.size}).sum::<u32>()))]
pub async fn decode(
2022-10-08 10:30:12 +00:00
&mut self,
batches: Vec<Batch>,
) -> Result<(Vec<Generation>, Option<Batch>)> {
2023-02-13 12:02:45 +00:00
let request = tonic::Request::new(DecodeRequest { batches }).inject_context();
let response = self.stub.decode(request).await?.into_inner();
Ok((response.generations, response.batch))
}
2022-10-08 10:30:12 +00:00
}