mirror of
https://github.com/GreptimeTeam/greptimedb.git
synced 2026-01-05 21:02:58 +00:00
* feat: implement distributed tracing * fix: change usage of span * fix: use otlp as exporter * chore: update dependence * chore: add span info * chore: add alias * chore: use instrument instead of trace
155 lines
5.1 KiB
Rust
155 lines
5.1 KiB
Rust
// Copyright 2023 Greptime Team
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
use std::sync::Arc;
|
|
|
|
use api::v1::meta::Partition;
|
|
use api::v1::region::{QueryRequest, RegionRequest, RegionResponse};
|
|
use async_trait::async_trait;
|
|
use client::region::check_response_header;
|
|
use common_error::ext::BoxedError;
|
|
use common_meta::datanode_manager::{AffectedRows, Datanode, DatanodeManager, DatanodeRef};
|
|
use common_meta::ddl::{TableMetadataAllocator, TableMetadataAllocatorContext};
|
|
use common_meta::error::{self as meta_error, Result as MetaResult};
|
|
use common_meta::kv_backend::KvBackendRef;
|
|
use common_meta::peer::Peer;
|
|
use common_meta::rpc::router::{Region, RegionRoute};
|
|
use common_meta::sequence::{Sequence, SequenceRef};
|
|
use common_recordbatch::SendableRecordBatchStream;
|
|
use common_telemetry::tracing;
|
|
use common_telemetry::tracing_context::{FutureExt, TracingContext};
|
|
use datanode::region_server::RegionServer;
|
|
use servers::grpc::region_server::RegionServerHandler;
|
|
use snafu::{OptionExt, ResultExt};
|
|
use store_api::storage::{RegionId, TableId};
|
|
use table::metadata::RawTableInfo;
|
|
|
|
use crate::error::{InvalidRegionRequestSnafu, InvokeRegionServerSnafu, Result};
|
|
|
|
const TABLE_ID_SEQ: &str = "table_id";
|
|
|
|
pub struct StandaloneDatanodeManager(pub RegionServer);
|
|
|
|
#[async_trait]
|
|
impl DatanodeManager for StandaloneDatanodeManager {
|
|
async fn datanode(&self, _datanode: &Peer) -> DatanodeRef {
|
|
RegionInvoker::arc(self.0.clone())
|
|
}
|
|
}
|
|
|
|
/// Relative to [client::region::RegionRequester]
|
|
struct RegionInvoker {
|
|
region_server: RegionServer,
|
|
}
|
|
|
|
impl RegionInvoker {
|
|
pub fn arc(region_server: RegionServer) -> Arc<Self> {
|
|
Arc::new(Self { region_server })
|
|
}
|
|
|
|
async fn handle_inner(&self, request: RegionRequest) -> Result<RegionResponse> {
|
|
let body = request.body.with_context(|| InvalidRegionRequestSnafu {
|
|
reason: "body not found",
|
|
})?;
|
|
|
|
self.region_server
|
|
.handle(body)
|
|
.await
|
|
.context(InvokeRegionServerSnafu)
|
|
}
|
|
}
|
|
|
|
#[async_trait]
|
|
impl Datanode for RegionInvoker {
|
|
async fn handle(&self, request: RegionRequest) -> MetaResult<AffectedRows> {
|
|
let span = request
|
|
.header
|
|
.as_ref()
|
|
.map(|h| TracingContext::from_w3c(&h.tracing_context))
|
|
.unwrap_or_default()
|
|
.attach(tracing::info_span!("RegionInvoker::handle_region_request"));
|
|
let response = self
|
|
.handle_inner(request)
|
|
.trace(span)
|
|
.await
|
|
.map_err(BoxedError::new)
|
|
.context(meta_error::ExternalSnafu)?;
|
|
check_response_header(response.header)
|
|
.map_err(BoxedError::new)
|
|
.context(meta_error::ExternalSnafu)?;
|
|
Ok(response.affected_rows)
|
|
}
|
|
|
|
async fn handle_query(&self, request: QueryRequest) -> MetaResult<SendableRecordBatchStream> {
|
|
let span = request
|
|
.header
|
|
.as_ref()
|
|
.map(|h| TracingContext::from_w3c(&h.tracing_context))
|
|
.unwrap_or_default()
|
|
.attach(tracing::info_span!("RegionInvoker::handle_query"));
|
|
self.region_server
|
|
.handle_read(request)
|
|
.trace(span)
|
|
.await
|
|
.map_err(BoxedError::new)
|
|
.context(meta_error::ExternalSnafu)
|
|
}
|
|
}
|
|
|
|
pub(crate) struct StandaloneTableMetadataCreator {
|
|
table_id_sequence: SequenceRef,
|
|
}
|
|
|
|
impl StandaloneTableMetadataCreator {
|
|
pub fn new(kv_backend: KvBackendRef) -> Self {
|
|
Self {
|
|
table_id_sequence: Arc::new(Sequence::new(TABLE_ID_SEQ, 1024, 10, kv_backend)),
|
|
}
|
|
}
|
|
}
|
|
|
|
#[async_trait]
|
|
impl TableMetadataAllocator for StandaloneTableMetadataCreator {
|
|
async fn create(
|
|
&self,
|
|
_ctx: &TableMetadataAllocatorContext,
|
|
raw_table_info: &mut RawTableInfo,
|
|
partitions: &[Partition],
|
|
) -> MetaResult<(TableId, Vec<RegionRoute>)> {
|
|
let table_id = self.table_id_sequence.next().await? as u32;
|
|
raw_table_info.ident.table_id = table_id;
|
|
let region_routes = partitions
|
|
.iter()
|
|
.enumerate()
|
|
.map(|(i, partition)| {
|
|
let region = Region {
|
|
id: RegionId::new(table_id, i as u32),
|
|
partition: Some(partition.clone().into()),
|
|
..Default::default()
|
|
};
|
|
// It's only a placeholder.
|
|
let peer = Peer::default();
|
|
RegionRoute {
|
|
region,
|
|
leader_peer: Some(peer),
|
|
follower_peers: vec![],
|
|
leader_status: None,
|
|
}
|
|
})
|
|
.collect::<Vec<_>>();
|
|
|
|
Ok((table_id, region_routes))
|
|
}
|
|
}
|