mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2025-01-21 16:31:54 +00:00
CLI: fix channel stats display
The overall number of updates/withdrawals received, as well as the number of routes limited, were not updated.
This commit is contained in:
parent
4c59e20968
commit
294a768a9d
14
nest/proto.c
14
nest/proto.c
@ -2587,20 +2587,20 @@ channel_show_stats(struct channel *c)
|
|||||||
cli_msg(-1006, " Routes: %u imported, %u exported, %u preferred",
|
cli_msg(-1006, " Routes: %u imported, %u exported, %u preferred",
|
||||||
in_routes, out_routes, SRI(pref));
|
in_routes, out_routes, SRI(pref));
|
||||||
|
|
||||||
cli_msg(-1006, " Route change stats: received rejected filtered ignored RX limit IN limit accepted");
|
cli_msg(-1006, " Route change stats: received rejected filtered ignored RX limit limit accepted");
|
||||||
cli_msg(-1006, " Import updates: %10u %10u %10u %10u %10u %10u %10u",
|
cli_msg(-1006, " Import updates: %10u %10u %10u %10u %10u %10u %10u",
|
||||||
SCI(updates_received), SCI(updates_invalid),
|
SCI(updates_received), SCI(updates_invalid),
|
||||||
SCI(updates_filtered), SRI(updates_ignored),
|
SCI(updates_filtered), SRI(updates_ignored),
|
||||||
SCI(updates_limited_rx), SCI(updates_limited_in),
|
SCI(updates_limited_rx), SCI(updates_limited_in),
|
||||||
SRI(updates_accepted));
|
SRI(updates_accepted));
|
||||||
cli_msg(-1006, " Import withdraws: %10u %10u --- %10u --- %10u",
|
cli_msg(-1006, " Import withdraws: %10u %10u --- %10u --- --- %10u",
|
||||||
SCI(withdraws_received), SCI(withdraws_invalid),
|
SCI(withdraws_received), SCI(withdraws_invalid),
|
||||||
SRI(withdraws_ignored), SRI(withdraws_accepted));
|
SRI(withdraws_ignored), SRI(withdraws_accepted));
|
||||||
cli_msg(-1006, " Export updates: %10u %10u %10u --- %10u %10u",
|
cli_msg(-1006, " Export updates: %10u %10u %10u %10u --- %10u %10u",
|
||||||
SRE(updates_received), SCE(updates_rejected),
|
SRE(updates_received), SCE(updates_rejected), SCE(updates_filtered),
|
||||||
SCE(updates_filtered), SCE(updates_limited), SCE(updates_accepted));
|
SCE(updates_ignored), SCE(updates_limited), SCE(updates_accepted));
|
||||||
cli_msg(-1006, " Export withdraws: %10u --- --- --- ---%10u",
|
cli_msg(-1006, " Export withdraws: %10u --- --- %10u --- --- %10u",
|
||||||
SRE(withdraws_received), SCE(withdraws_accepted));
|
SRE(withdraws_received), SCE(withdraws_ignored), SCE(withdraws_accepted));
|
||||||
|
|
||||||
#undef SRI
|
#undef SRI
|
||||||
#undef SRE
|
#undef SRE
|
||||||
|
@ -637,10 +637,12 @@ struct channel {
|
|||||||
|
|
||||||
struct channel_export_stats {
|
struct channel_export_stats {
|
||||||
/* Export - from core to protocol */
|
/* Export - from core to protocol */
|
||||||
|
u32 updates_ignored; /* Number of route updates ignored (squashed) by channel */
|
||||||
u32 updates_rejected; /* Number of route updates rejected by protocol */
|
u32 updates_rejected; /* Number of route updates rejected by protocol */
|
||||||
u32 updates_filtered; /* Number of route updates rejected by filters */
|
u32 updates_filtered; /* Number of route updates rejected by filters */
|
||||||
u32 updates_accepted; /* Number of route updates accepted and exported */
|
u32 updates_accepted; /* Number of route updates accepted and exported */
|
||||||
u32 updates_limited; /* Number of route updates exceeding the out_limit */
|
u32 updates_limited; /* Number of route updates exceeding the out_limit */
|
||||||
|
u32 withdraws_ignored; /* Number of route withdraws ignored (squashed) by channel */
|
||||||
u32 withdraws_accepted; /* Number of route withdraws accepted and processed */
|
u32 withdraws_accepted; /* Number of route withdraws accepted and processed */
|
||||||
} export_stats;
|
} export_stats;
|
||||||
|
|
||||||
|
@ -104,6 +104,7 @@ rt_export_get(struct rt_export_request *r)
|
|||||||
{
|
{
|
||||||
/* Feeding more */
|
/* Feeding more */
|
||||||
rtex_trace(r, D_ROUTES, "Feeding %N", feed->ni->addr);
|
rtex_trace(r, D_ROUTES, "Feeding %N", feed->ni->addr);
|
||||||
|
r->stats.updates_received += feed->count_routes;
|
||||||
EXPORT_FOUND(RT_EXPORT_FEED);
|
EXPORT_FOUND(RT_EXPORT_FEED);
|
||||||
}
|
}
|
||||||
else if (rt_export_get_state(r) == TES_DOWN)
|
else if (rt_export_get_state(r) == TES_DOWN)
|
||||||
@ -158,12 +159,18 @@ rt_export_get(struct rt_export_request *r)
|
|||||||
|
|
||||||
ASSERT_DIE(feed && (feed != &rt_feed_index_out_of_range));
|
ASSERT_DIE(feed && (feed != &rt_feed_index_out_of_range));
|
||||||
|
|
||||||
|
r->stats.updates_received += feed->count_routes;
|
||||||
EXPORT_FOUND(RT_EXPORT_FEED);
|
EXPORT_FOUND(RT_EXPORT_FEED);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* OK, now this actually is an update, thank you for your patience */
|
/* OK, now this actually is an update, thank you for your patience */
|
||||||
rtex_trace(r, D_ROUTES, "Updating %N, seq %lu", n, update->seq);
|
rtex_trace(r, D_ROUTES, "Updating %N, seq %lu", n, update->seq);
|
||||||
|
|
||||||
|
if (update->new)
|
||||||
|
r->stats.updates_received++;
|
||||||
|
else
|
||||||
|
r->stats.withdraws_received++;
|
||||||
|
|
||||||
EXPORT_FOUND(RT_EXPORT_UPDATE);
|
EXPORT_FOUND(RT_EXPORT_UPDATE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1131,7 +1131,7 @@ do_rt_notify(struct channel *c, const net_addr *net, rte *new, const rte *old)
|
|||||||
if (!old && new)
|
if (!old && new)
|
||||||
if (CHANNEL_LIMIT_PUSH(c, OUT))
|
if (CHANNEL_LIMIT_PUSH(c, OUT))
|
||||||
{
|
{
|
||||||
stats->updates_rejected++;
|
stats->updates_limited++;
|
||||||
channel_rte_trace_out(D_FILTERS, c, new, "rejected [limit]");
|
channel_rte_trace_out(D_FILTERS, c, new, "rejected [limit]");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1165,6 +1165,10 @@ rt_notify_basic(struct channel *c, const rte *new, const rte *old)
|
|||||||
{
|
{
|
||||||
const rte *trte = new ?: old;
|
const rte *trte = new ?: old;
|
||||||
|
|
||||||
|
/* Have we exported the old route? */
|
||||||
|
if (old && !bmap_test(&c->export_accepted_map, old->id))
|
||||||
|
old = NULL;
|
||||||
|
|
||||||
/* Ignore invalid routes */
|
/* Ignore invalid routes */
|
||||||
if (!rte_is_valid(new))
|
if (!rte_is_valid(new))
|
||||||
new = NULL;
|
new = NULL;
|
||||||
@ -1175,6 +1179,7 @@ rt_notify_basic(struct channel *c, const rte *new, const rte *old)
|
|||||||
if (!new && !old)
|
if (!new && !old)
|
||||||
{
|
{
|
||||||
channel_rte_trace_out(D_ROUTES, c, trte, "idempotent withdraw (filtered on import)");
|
channel_rte_trace_out(D_ROUTES, c, trte, "idempotent withdraw (filtered on import)");
|
||||||
|
c->export_stats.withdraws_ignored++;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1196,14 +1201,11 @@ rt_notify_basic(struct channel *c, const rte *new, const rte *old)
|
|||||||
np = export_filter(c, &n0, 0);
|
np = export_filter(c, &n0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Have we exported the old route? */
|
|
||||||
if (old && !bmap_test(&c->export_accepted_map, old->id))
|
|
||||||
old = NULL;
|
|
||||||
|
|
||||||
/* Withdraw to withdraw. */
|
/* Withdraw to withdraw. */
|
||||||
if (!np && !old)
|
if (!np && !old)
|
||||||
{
|
{
|
||||||
channel_rte_trace_out(D_ROUTES, c, trte, "idempotent withdraw (filtered on export)");
|
channel_rte_trace_out(D_ROUTES, c, trte, "idempotent withdraw (filtered on export)");
|
||||||
|
/* No stats update, done in export_filter() */
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1523,6 +1525,18 @@ channel_notify_basic(void *_channel)
|
|||||||
*/
|
*/
|
||||||
if ((rpe->it.old == new) && (new || src && (src == rpe->it.new->src)))
|
if ((rpe->it.old == new) && (new || src && (src == rpe->it.new->src)))
|
||||||
{
|
{
|
||||||
|
/* Fix the stats: the old item is squashed (ignored) */
|
||||||
|
if (new)
|
||||||
|
c->export_stats.updates_ignored++;
|
||||||
|
else
|
||||||
|
c->export_stats.withdraws_ignored++;
|
||||||
|
|
||||||
|
/* Fix the stats: the new update is received */
|
||||||
|
if (rpe->it.new)
|
||||||
|
c->out_req.stats.updates_received++;
|
||||||
|
else
|
||||||
|
c->out_req.stats.withdraws_received++;
|
||||||
|
|
||||||
new = rpe->it.new;
|
new = rpe->it.new;
|
||||||
rt_export_processed(&c->out_req, rpe->it.seq);
|
rt_export_processed(&c->out_req, rpe->it.seq);
|
||||||
}
|
}
|
||||||
@ -1538,7 +1552,10 @@ channel_notify_basic(void *_channel)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (!new && !old)
|
else if (!new && !old)
|
||||||
|
{
|
||||||
channel_rte_trace_out(D_ROUTES, c, u->update->new, "idempotent withdraw (squash)");
|
channel_rte_trace_out(D_ROUTES, c, u->update->new, "idempotent withdraw (squash)");
|
||||||
|
c->export_stats.withdraws_ignored++;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
rt_notify_basic(c, new, old);
|
rt_notify_basic(c, new, old);
|
||||||
|
|
||||||
@ -2147,7 +2164,10 @@ channel_preimport(struct rt_import_request *req, rte *new, const rte *old)
|
|||||||
|
|
||||||
if (new && !old)
|
if (new && !old)
|
||||||
if (CHANNEL_LIMIT_PUSH(c, RX))
|
if (CHANNEL_LIMIT_PUSH(c, RX))
|
||||||
|
{
|
||||||
|
c->import_stats.updates_limited_rx++;
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (!new && old)
|
if (!new && old)
|
||||||
CHANNEL_LIMIT_POP(c, RX);
|
CHANNEL_LIMIT_POP(c, RX);
|
||||||
@ -2162,7 +2182,10 @@ channel_preimport(struct rt_import_request *req, rte *new, const rte *old)
|
|||||||
if (c->in_keep & RIK_REJECTED)
|
if (c->in_keep & RIK_REJECTED)
|
||||||
new->flags |= REF_FILTERED;
|
new->flags |= REF_FILTERED;
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
c->import_stats.updates_limited_in++;
|
||||||
verdict = 0;
|
verdict = 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (!new_in && old_in)
|
if (!new_in && old_in)
|
||||||
CHANNEL_LIMIT_POP(c, IN);
|
CHANNEL_LIMIT_POP(c, IN);
|
||||||
|
Loading…
Reference in New Issue
Block a user