mirror of
https://gitlab.com/veilid/veilid.git
synced 2025-01-14 00:39:50 -05:00
remote route recordkeeping fix
This commit is contained in:
parent
55fed573d6
commit
c484a2ae14
@ -915,10 +915,14 @@ impl RouteSpecStore {
|
|||||||
F: FnMut(&RouteId, &RemotePrivateRouteInfo) -> Option<R>,
|
F: FnMut(&RouteId, &RemotePrivateRouteInfo) -> Option<R>,
|
||||||
{
|
{
|
||||||
let inner = self.inner.lock();
|
let inner = self.inner.lock();
|
||||||
let mut out = Vec::with_capacity(inner.cache.get_remote_private_route_count());
|
let cur_ts = get_aligned_timestamp();
|
||||||
for info in inner.cache.iter_remote_private_routes() {
|
let remote_route_ids = inner.cache.get_remote_private_route_ids(cur_ts);
|
||||||
if let Some(x) = filter(info.0, info.1) {
|
let mut out = Vec::with_capacity(remote_route_ids.len());
|
||||||
out.push(x);
|
for id in remote_route_ids {
|
||||||
|
if let Some(rpri) = inner.cache.peek_remote_private_route(cur_ts, &id) {
|
||||||
|
if let Some(x) = filter(&id, rpri) {
|
||||||
|
out.push(x);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
out
|
out
|
||||||
@ -928,7 +932,7 @@ impl RouteSpecStore {
|
|||||||
pub fn debug_route(&self, id: &RouteId) -> Option<String> {
|
pub fn debug_route(&self, id: &RouteId) -> Option<String> {
|
||||||
let inner = &mut *self.inner.lock();
|
let inner = &mut *self.inner.lock();
|
||||||
let cur_ts = get_aligned_timestamp();
|
let cur_ts = get_aligned_timestamp();
|
||||||
if let Some(rpri) = inner.cache.peek_remote_private_route_mut(cur_ts, id) {
|
if let Some(rpri) = inner.cache.peek_remote_private_route(cur_ts, id) {
|
||||||
return Some(format!("{:#?}", rpri));
|
return Some(format!("{:#?}", rpri));
|
||||||
}
|
}
|
||||||
if let Some(rssd) = inner.content.get_detail(id) {
|
if let Some(rssd) = inner.content.get_detail(id) {
|
||||||
@ -1587,7 +1591,7 @@ impl RouteSpecStore {
|
|||||||
/// Check to see if this remote (not ours) private route has seen our current node info yet
|
/// Check to see if this remote (not ours) private route has seen our current node info yet
|
||||||
/// This happens when you communicate with a private route without a safety route
|
/// This happens when you communicate with a private route without a safety route
|
||||||
pub fn has_remote_private_route_seen_our_node_info(&self, key: &PublicKey) -> bool {
|
pub fn has_remote_private_route_seen_our_node_info(&self, key: &PublicKey) -> bool {
|
||||||
let inner = &mut *self.inner.lock();
|
let inner = &*self.inner.lock();
|
||||||
|
|
||||||
// Check for local route. If this is not a remote private route,
|
// Check for local route. If this is not a remote private route,
|
||||||
// we may be running a test and using our own local route as the destination private route.
|
// we may be running a test and using our own local route as the destination private route.
|
||||||
@ -1598,7 +1602,7 @@ impl RouteSpecStore {
|
|||||||
|
|
||||||
if let Some(rrid) = inner.cache.get_remote_private_route_id_by_key(key) {
|
if let Some(rrid) = inner.cache.get_remote_private_route_id_by_key(key) {
|
||||||
let cur_ts = get_aligned_timestamp();
|
let cur_ts = get_aligned_timestamp();
|
||||||
if let Some(rpri) = inner.cache.peek_remote_private_route_mut(cur_ts, &rrid) {
|
if let Some(rpri) = inner.cache.peek_remote_private_route(cur_ts, &rrid) {
|
||||||
let our_node_info_ts = self
|
let our_node_info_ts = self
|
||||||
.unlocked_inner
|
.unlocked_inner
|
||||||
.routing_table
|
.routing_table
|
||||||
@ -1646,7 +1650,7 @@ impl RouteSpecStore {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Get the route statistics for any route we know about, local or remote
|
/// Get the route statistics for any route we know about, local or remote
|
||||||
pub fn with_route_stats<F, R>(&self, cur_ts: Timestamp, key: &PublicKey, f: F) -> Option<R>
|
pub fn with_route_stats_mut<F, R>(&self, cur_ts: Timestamp, key: &PublicKey, f: F) -> Option<R>
|
||||||
where
|
where
|
||||||
F: FnOnce(&mut RouteStats) -> R,
|
F: FnOnce(&mut RouteStats) -> R,
|
||||||
{
|
{
|
||||||
|
@ -45,7 +45,7 @@ impl RemotePrivateRouteInfo {
|
|||||||
&mut self.stats
|
&mut self.stats
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn has_seen_our_node_info_ts(&mut self, our_node_info_ts: Timestamp) -> bool {
|
pub fn has_seen_our_node_info_ts(&self, our_node_info_ts: Timestamp) -> bool {
|
||||||
self.last_seen_our_node_info_ts == our_node_info_ts
|
self.last_seen_our_node_info_ts == our_node_info_ts
|
||||||
}
|
}
|
||||||
pub fn set_last_seen_our_node_info_ts(&mut self, last_seen_our_node_info_ts: Timestamp) {
|
pub fn set_last_seen_our_node_info_ts(&mut self, last_seen_our_node_info_ts: Timestamp) {
|
||||||
|
@ -173,16 +173,18 @@ impl RouteSpecStoreCache {
|
|||||||
id
|
id
|
||||||
}
|
}
|
||||||
|
|
||||||
/// get count of remote private routes in cache
|
|
||||||
pub fn get_remote_private_route_count(&self) -> usize {
|
|
||||||
self.remote_private_route_set_cache.len()
|
|
||||||
}
|
|
||||||
|
|
||||||
/// iterate all of the remote private routes we have in the cache
|
/// iterate all of the remote private routes we have in the cache
|
||||||
pub fn iter_remote_private_routes(
|
pub fn get_remote_private_route_ids(&self, cur_ts: Timestamp) -> Vec<RouteId> {
|
||||||
&self,
|
self.remote_private_route_set_cache
|
||||||
) -> hashlink::linked_hash_map::Iter<RouteId, RemotePrivateRouteInfo> {
|
.iter()
|
||||||
self.remote_private_route_set_cache.iter()
|
.filter_map(|(id, rpri)| {
|
||||||
|
if !rpri.did_expire(cur_ts) {
|
||||||
|
Some(*id)
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.collect()
|
||||||
}
|
}
|
||||||
|
|
||||||
/// remote private route cache accessor
|
/// remote private route cache accessor
|
||||||
@ -217,6 +219,21 @@ impl RouteSpecStoreCache {
|
|||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// remote private route cache accessor without lru action
|
||||||
|
/// will not LRU entries but may expire entries and not return them if they are stale
|
||||||
|
pub fn peek_remote_private_route(
|
||||||
|
&self,
|
||||||
|
cur_ts: Timestamp,
|
||||||
|
id: &RouteId,
|
||||||
|
) -> Option<&RemotePrivateRouteInfo> {
|
||||||
|
if let Some(rpri) = self.remote_private_route_set_cache.peek(id) {
|
||||||
|
if !rpri.did_expire(cur_ts) {
|
||||||
|
return Some(rpri);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
None
|
||||||
|
}
|
||||||
|
|
||||||
/// mutable remote private route cache accessor without lru action
|
/// mutable remote private route cache accessor without lru action
|
||||||
/// will not LRU entries but may expire entries and not return them if they are stale
|
/// will not LRU entries but may expire entries and not return them if they are stale
|
||||||
pub fn peek_remote_private_route_mut(
|
pub fn peek_remote_private_route_mut(
|
||||||
|
@ -938,12 +938,12 @@ impl RPCProcessor {
|
|||||||
// If safety route was in use, record failure to send there
|
// If safety route was in use, record failure to send there
|
||||||
if let Some(sr_pubkey) = &safety_route {
|
if let Some(sr_pubkey) = &safety_route {
|
||||||
let rss = self.routing_table.route_spec_store();
|
let rss = self.routing_table.route_spec_store();
|
||||||
rss.with_route_stats(send_ts, sr_pubkey, |s| s.record_send_failed());
|
rss.with_route_stats_mut(send_ts, sr_pubkey, |s| s.record_send_failed());
|
||||||
} else {
|
} else {
|
||||||
// If no safety route was in use, then it's the private route's fault if we have one
|
// If no safety route was in use, then it's the private route's fault if we have one
|
||||||
if let Some(pr_pubkey) = &remote_private_route {
|
if let Some(pr_pubkey) = &remote_private_route {
|
||||||
let rss = self.routing_table.route_spec_store();
|
let rss = self.routing_table.route_spec_store();
|
||||||
rss.with_route_stats(send_ts, pr_pubkey, |s| s.record_send_failed());
|
rss.with_route_stats_mut(send_ts, pr_pubkey, |s| s.record_send_failed());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -972,19 +972,19 @@ impl RPCProcessor {
|
|||||||
// If safety route was used, record question lost there
|
// If safety route was used, record question lost there
|
||||||
if let Some(sr_pubkey) = &safety_route {
|
if let Some(sr_pubkey) = &safety_route {
|
||||||
let rss = self.routing_table.route_spec_store();
|
let rss = self.routing_table.route_spec_store();
|
||||||
rss.with_route_stats(send_ts, sr_pubkey, |s| {
|
rss.with_route_stats_mut(send_ts, sr_pubkey, |s| {
|
||||||
s.record_question_lost();
|
s.record_question_lost();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
// If remote private route was used, record question lost there
|
// If remote private route was used, record question lost there
|
||||||
if let Some(rpr_pubkey) = &remote_private_route {
|
if let Some(rpr_pubkey) = &remote_private_route {
|
||||||
rss.with_route_stats(send_ts, rpr_pubkey, |s| {
|
rss.with_route_stats_mut(send_ts, rpr_pubkey, |s| {
|
||||||
s.record_question_lost();
|
s.record_question_lost();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
// If private route was used, record question lost there
|
// If private route was used, record question lost there
|
||||||
if let Some(pr_pubkey) = &private_route {
|
if let Some(pr_pubkey) = &private_route {
|
||||||
rss.with_route_stats(send_ts, pr_pubkey, |s| {
|
rss.with_route_stats_mut(send_ts, pr_pubkey, |s| {
|
||||||
s.record_question_lost();
|
s.record_question_lost();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1018,7 +1018,7 @@ impl RPCProcessor {
|
|||||||
|
|
||||||
// If safety route was used, record send there
|
// If safety route was used, record send there
|
||||||
if let Some(sr_pubkey) = &safety_route {
|
if let Some(sr_pubkey) = &safety_route {
|
||||||
rss.with_route_stats(send_ts, sr_pubkey, |s| {
|
rss.with_route_stats_mut(send_ts, sr_pubkey, |s| {
|
||||||
s.record_sent(send_ts, bytes);
|
s.record_sent(send_ts, bytes);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1026,7 +1026,7 @@ impl RPCProcessor {
|
|||||||
// If remote private route was used, record send there
|
// If remote private route was used, record send there
|
||||||
if let Some(pr_pubkey) = &remote_private_route {
|
if let Some(pr_pubkey) = &remote_private_route {
|
||||||
let rss = self.routing_table.route_spec_store();
|
let rss = self.routing_table.route_spec_store();
|
||||||
rss.with_route_stats(send_ts, pr_pubkey, |s| {
|
rss.with_route_stats_mut(send_ts, pr_pubkey, |s| {
|
||||||
s.record_sent(send_ts, bytes);
|
s.record_sent(send_ts, bytes);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1059,7 +1059,7 @@ impl RPCProcessor {
|
|||||||
|
|
||||||
// If safety route was used, record route there
|
// If safety route was used, record route there
|
||||||
if let Some(sr_pubkey) = &safety_route {
|
if let Some(sr_pubkey) = &safety_route {
|
||||||
rss.with_route_stats(send_ts, sr_pubkey, |s| {
|
rss.with_route_stats_mut(send_ts, sr_pubkey, |s| {
|
||||||
// If we received an answer, the safety route we sent over can be considered tested
|
// If we received an answer, the safety route we sent over can be considered tested
|
||||||
s.record_tested(recv_ts);
|
s.record_tested(recv_ts);
|
||||||
|
|
||||||
@ -1070,7 +1070,7 @@ impl RPCProcessor {
|
|||||||
|
|
||||||
// If local private route was used, record route there
|
// If local private route was used, record route there
|
||||||
if let Some(pr_pubkey) = &reply_private_route {
|
if let Some(pr_pubkey) = &reply_private_route {
|
||||||
rss.with_route_stats(send_ts, pr_pubkey, |s| {
|
rss.with_route_stats_mut(send_ts, pr_pubkey, |s| {
|
||||||
// Record received bytes
|
// Record received bytes
|
||||||
s.record_received(recv_ts, bytes);
|
s.record_received(recv_ts, bytes);
|
||||||
|
|
||||||
@ -1081,7 +1081,7 @@ impl RPCProcessor {
|
|||||||
|
|
||||||
// If remote private route was used, record there
|
// If remote private route was used, record there
|
||||||
if let Some(rpr_pubkey) = &remote_private_route {
|
if let Some(rpr_pubkey) = &remote_private_route {
|
||||||
rss.with_route_stats(send_ts, rpr_pubkey, |s| {
|
rss.with_route_stats_mut(send_ts, rpr_pubkey, |s| {
|
||||||
// Record received bytes
|
// Record received bytes
|
||||||
s.record_received(recv_ts, bytes);
|
s.record_received(recv_ts, bytes);
|
||||||
|
|
||||||
@ -1106,12 +1106,12 @@ impl RPCProcessor {
|
|||||||
// then we must have received with a local private route too, per the design rules
|
// then we must have received with a local private route too, per the design rules
|
||||||
if let Some(sr_pubkey) = &safety_route {
|
if let Some(sr_pubkey) = &safety_route {
|
||||||
let rss = self.routing_table.route_spec_store();
|
let rss = self.routing_table.route_spec_store();
|
||||||
rss.with_route_stats(send_ts, sr_pubkey, |s| {
|
rss.with_route_stats_mut(send_ts, sr_pubkey, |s| {
|
||||||
s.record_latency(total_latency / 2u64);
|
s.record_latency(total_latency / 2u64);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
if let Some(pr_pubkey) = &reply_private_route {
|
if let Some(pr_pubkey) = &reply_private_route {
|
||||||
rss.with_route_stats(send_ts, pr_pubkey, |s| {
|
rss.with_route_stats_mut(send_ts, pr_pubkey, |s| {
|
||||||
s.record_latency(total_latency / 2u64);
|
s.record_latency(total_latency / 2u64);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1137,7 +1137,7 @@ impl RPCProcessor {
|
|||||||
|
|
||||||
// This may record nothing if the remote safety route is not also
|
// This may record nothing if the remote safety route is not also
|
||||||
// a remote private route that been imported, but that's okay
|
// a remote private route that been imported, but that's okay
|
||||||
rss.with_route_stats(recv_ts, &d.remote_safety_route, |s| {
|
rss.with_route_stats_mut(recv_ts, &d.remote_safety_route, |s| {
|
||||||
s.record_received(recv_ts, bytes);
|
s.record_received(recv_ts, bytes);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1149,12 +1149,12 @@ impl RPCProcessor {
|
|||||||
// a remote private route that been imported, but that's okay
|
// a remote private route that been imported, but that's okay
|
||||||
// it could also be a node id if no remote safety route was used
|
// it could also be a node id if no remote safety route was used
|
||||||
// in which case this also will do nothing
|
// in which case this also will do nothing
|
||||||
rss.with_route_stats(recv_ts, &d.remote_safety_route, |s| {
|
rss.with_route_stats_mut(recv_ts, &d.remote_safety_route, |s| {
|
||||||
s.record_received(recv_ts, bytes);
|
s.record_received(recv_ts, bytes);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Record for our local private route we received over
|
// Record for our local private route we received over
|
||||||
rss.with_route_stats(recv_ts, &d.private_route, |s| {
|
rss.with_route_stats_mut(recv_ts, &d.private_route, |s| {
|
||||||
s.record_received(recv_ts, bytes);
|
s.record_received(recv_ts, bytes);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -1724,6 +1724,7 @@ impl VeilidAPI {
|
|||||||
parse_duration,
|
parse_duration,
|
||||||
)
|
)
|
||||||
.ok()
|
.ok()
|
||||||
|
.map(|dur| dur + get_timestamp())
|
||||||
.unwrap_or_else(|| {
|
.unwrap_or_else(|| {
|
||||||
rest_defaults = true;
|
rest_defaults = true;
|
||||||
Default::default()
|
Default::default()
|
||||||
|
Loading…
Reference in New Issue
Block a user