mirror of
https://github.com/EasyTier/EasyTier.git
synced 2026-05-07 02:09:06 +00:00
ipv4-peerid table should use peer with least hop (#958)
sometimes route table may not be updated in time, so some dead nodes are still showing in the peer list. when generating ipv4-peer table, we should avoid these dead devices overrides the entry of healthy nodes.
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
use std::{
|
use std::{
|
||||||
|
collections::BTreeSet,
|
||||||
io,
|
io,
|
||||||
net::Ipv4Addr,
|
net::Ipv4Addr,
|
||||||
pin::Pin,
|
pin::Pin,
|
||||||
@@ -569,26 +570,26 @@ impl NicCtx {
|
|||||||
let ifname = nic.ifname().to_owned();
|
let ifname = nic.ifname().to_owned();
|
||||||
|
|
||||||
self.tasks.spawn(async move {
|
self.tasks.spawn(async move {
|
||||||
let mut cur_proxy_cidrs = vec![];
|
let mut cur_proxy_cidrs = BTreeSet::new();
|
||||||
loop {
|
loop {
|
||||||
let mut proxy_cidrs = vec![];
|
let mut proxy_cidrs = BTreeSet::new();
|
||||||
let routes = peer_mgr.list_routes().await;
|
let routes = peer_mgr.list_routes().await;
|
||||||
for r in routes {
|
for r in routes {
|
||||||
for cidr in r.proxy_cidrs {
|
for cidr in r.proxy_cidrs {
|
||||||
let Ok(cidr) = cidr.parse::<cidr::Ipv4Cidr>() else {
|
let Ok(cidr) = cidr.parse::<cidr::Ipv4Cidr>() else {
|
||||||
continue;
|
continue;
|
||||||
};
|
};
|
||||||
proxy_cidrs.push(cidr);
|
proxy_cidrs.insert(cidr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// add vpn portal cidr to proxy_cidrs
|
// add vpn portal cidr to proxy_cidrs
|
||||||
if let Some(vpn_cfg) = global_ctx.config.get_vpn_portal_config() {
|
if let Some(vpn_cfg) = global_ctx.config.get_vpn_portal_config() {
|
||||||
proxy_cidrs.push(vpn_cfg.client_cidr);
|
proxy_cidrs.insert(vpn_cfg.client_cidr);
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(routes) = global_ctx.config.get_routes() {
|
if let Some(routes) = global_ctx.config.get_routes() {
|
||||||
// if has manual routes, just override entire proxy_cidrs
|
// if has manual routes, just override entire proxy_cidrs
|
||||||
proxy_cidrs = routes;
|
proxy_cidrs = routes.into_iter().collect();
|
||||||
}
|
}
|
||||||
|
|
||||||
// if route is in cur_proxy_cidrs but not in proxy_cidrs, delete it.
|
// if route is in cur_proxy_cidrs but not in proxy_cidrs, delete it.
|
||||||
|
|||||||
@@ -854,11 +854,36 @@ impl RouteTable {
|
|||||||
|
|
||||||
self.peer_infos.insert(*peer_id, info.clone());
|
self.peer_infos.insert(*peer_id, info.clone());
|
||||||
|
|
||||||
|
let is_new_peer_better = |old_peer_id: PeerId| -> bool {
|
||||||
|
let old_next_hop = self.get_next_hop(old_peer_id);
|
||||||
|
let new_next_hop = item.value();
|
||||||
|
old_next_hop.is_none()
|
||||||
|
|| new_next_hop.path_latency < old_next_hop.unwrap().path_latency
|
||||||
|
};
|
||||||
|
|
||||||
if let Some(ipv4_addr) = info.ipv4_addr {
|
if let Some(ipv4_addr) = info.ipv4_addr {
|
||||||
self.ipv4_peer_id_map.insert(ipv4_addr.into(), *peer_id);
|
self.ipv4_peer_id_map
|
||||||
|
.entry(ipv4_addr.into())
|
||||||
|
.and_modify(|v| {
|
||||||
|
if *v != *peer_id && is_new_peer_better(*v) {
|
||||||
|
self.ipv4_peer_id_map.insert(ipv4_addr.into(), *peer_id);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.or_insert(*peer_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
for cidr in info.proxy_cidrs.iter() {
|
for cidr in info.proxy_cidrs.iter() {
|
||||||
|
self.cidr_peer_id_map
|
||||||
|
.entry(cidr.parse().unwrap())
|
||||||
|
.and_modify(|v| {
|
||||||
|
if *v != *peer_id && is_new_peer_better(*v) {
|
||||||
|
// if the next hop is not set or the new next hop is better, update it.
|
||||||
|
self.cidr_peer_id_map
|
||||||
|
.insert(cidr.parse().unwrap(), *peer_id);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.or_insert(*peer_id);
|
||||||
|
|
||||||
self.cidr_peer_id_map
|
self.cidr_peer_id_map
|
||||||
.insert(cidr.parse().unwrap(), *peer_id);
|
.insert(cidr.parse().unwrap(), *peer_id);
|
||||||
}
|
}
|
||||||
@@ -1363,7 +1388,7 @@ impl PeerRouteServiceImpl {
|
|||||||
.dst_saved_conn_bitmap_version
|
.dst_saved_conn_bitmap_version
|
||||||
.get(&peer_id)
|
.get(&peer_id)
|
||||||
.map(|item| item.get());
|
.map(|item| item.get());
|
||||||
if Some(*local_version) != peer_version {
|
if peer_version.is_none() || peer_version.unwrap() < *local_version {
|
||||||
need_update = true;
|
need_update = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user