feat(cluster): implement Raft consensus with tracing and HTTP support

- Add Raft log and snapshot mechanisms for distributed consensus
- Integrate hyper HTTP server and client libraries for network communication
- Enhance tracing capabilities with structured logging and spans
- Add dependency tracking for new consensus-related crates
- Implement snapshot storage with serialization and persistence
- Add remote repository synchronization via Raft commands
- Include comprehensive tracing instrumentation across services
This commit is contained in:
zhenyi
2026-06-10 18:33:42 +08:00
parent 0207cde234
commit c32a7cad2f
10 changed files with 453 additions and 6 deletions
+30
View File
@@ -12,8 +12,12 @@ impl RefService for GitksService {
let m = crate::metrics::RequestMetrics::new("gitks.RefService/FindDefaultBranchName");
let inner = request.into_inner();
let _rate = self.acquire_rate_limit(inner.repository.as_ref()).await?;
let repo = self.repo_label(inner.repository.as_ref());
let span = tracing::info_span!("ref.find_default_branch_name", %repo);
let _enter = span.enter();
let gb = self.resolve(inner.repository.as_ref())?;
let resp = gb.find_default_branch_name().map_err(super::into_status)?;
tracing::info!(%repo, "find_default_branch_name done");
m.record("ok");
Ok(tonic::Response::new(resp))
}
@@ -25,8 +29,13 @@ impl RefService for GitksService {
let m = crate::metrics::RequestMetrics::new("gitks.RefService/RefExists");
let inner = request.into_inner();
let _rate = self.acquire_rate_limit(inner.repository.as_ref()).await?;
let repo = self.repo_label(inner.repository.as_ref());
let ref_name = inner.ref_name.clone();
let span = tracing::info_span!("ref.ref_exists", %repo, %ref_name);
let _enter = span.enter();
let gb = self.resolve(inner.repository.as_ref())?;
let resp = gb.ref_exists(inner).map_err(super::into_status)?;
tracing::info!(%repo, %ref_name, exists = resp.exists, "ref_exists done");
m.record("ok");
Ok(tonic::Response::new(resp))
}
@@ -38,8 +47,13 @@ impl RefService for GitksService {
let m = crate::metrics::RequestMetrics::new("gitks.RefService/UpdateReferences");
let inner = request.into_inner();
let _rate = self.acquire_rate_limit(inner.repository.as_ref()).await?;
let repo = self.repo_label(inner.repository.as_ref());
let updates_count = inner.updates.len();
let span = tracing::info_span!("ref.update_references", %repo, %updates_count);
let _enter = span.enter();
let gb = self.resolve(inner.repository.as_ref())?;
let resp = gb.update_references(inner).map_err(super::into_status)?;
tracing::info!(%repo, %updates_count, failed = resp.failed_refs.len(), "update_references done");
m.record("ok");
Ok(tonic::Response::new(resp))
}
@@ -51,8 +65,13 @@ impl RefService for GitksService {
let m = crate::metrics::RequestMetrics::new("gitks.RefService/DeleteRefs");
let inner = request.into_inner();
let _rate = self.acquire_rate_limit(inner.repository.as_ref()).await?;
let repo = self.repo_label(inner.repository.as_ref());
let ref_count = inner.ref_names.len();
let span = tracing::info_span!("ref.delete_refs", %repo, %ref_count);
let _enter = span.enter();
let gb = self.resolve(inner.repository.as_ref())?;
let resp = gb.delete_refs(inner).map_err(super::into_status)?;
tracing::info!(%repo, %ref_count, failed = resp.failed_refs.len(), "delete_refs done");
m.record("ok");
Ok(tonic::Response::new(resp))
}
@@ -64,8 +83,13 @@ impl RefService for GitksService {
let m = crate::metrics::RequestMetrics::new("gitks.RefService/FindRefsByOID");
let inner = request.into_inner();
let _rate = self.acquire_rate_limit(inner.repository.as_ref()).await?;
let repo = self.repo_label(inner.repository.as_ref());
let oid = inner.oid.clone();
let span = tracing::info_span!("ref.find_refs_by_oid", %repo, %oid);
let _enter = span.enter();
let gb = self.resolve(inner.repository.as_ref())?;
let resp = gb.find_refs_by_oid(inner).map_err(super::into_status)?;
tracing::info!(%repo, %oid, count = resp.refs.len(), "find_refs_by_oid done");
m.record("ok");
Ok(tonic::Response::new(resp))
}
@@ -77,8 +101,14 @@ impl RefService for GitksService {
let m = crate::metrics::RequestMetrics::new("gitks.RefService/ListRefs");
let inner = request.into_inner();
let _rate = self.acquire_rate_limit(inner.repository.as_ref()).await?;
let repo = self.repo_label(inner.repository.as_ref());
let prefixes = inner.prefixes.len();
let pattern = inner.pattern.clone();
let span = tracing::info_span!("ref.list_refs", %repo, %prefixes, %pattern);
let _enter = span.enter();
let gb = self.resolve(inner.repository.as_ref())?;
let resp = gb.list_all_refs(inner).map_err(super::into_status)?;
tracing::info!(%repo, count = resp.refs.len(), "list_refs done");
m.record("ok");
Ok(tonic::Response::new(resp))
}