通过将“/sys/class/net/br0/bridge/ageing_time”修改为最大值来设置老化时间。
# brctl showstp br0
br0
bridge id 8000.001018000000
designated root 8000.001018000000
....
ageing time 4294314.45
....
但是学习的表同时也会过时。
检查代码,我看到br_fdb.c中有一些溢出
static inline int has_expired(const struct net_bridge *br,
const struct net_bridge_fdb_entry *fdb)
{
return !fdb->is_static &&
(time_before_eq(fdb->updated + hold_time(br), jiffies));
}
fdb->updated +hold_time(br)
会溢出,那么学习表会被认为超时。
这是一个错误吗?
最佳答案
我想是的。但应该不是bug,只是一个不合适的地方。
如果您希望非静态 FDB 条目永不过期,但似乎此溢出会导致 has_expired() 返回 TRUE。
在 32 位计算机上,jiffies 通常每 50 天循环一次。这也会带来一些麻烦。但我想有时有些功能没有测试那么长时间。
在32位机器上,将time_before_eq()替换为time_before_eq64(),并将一些变量定义从“unsigned long”到“u64”应该可以工作。当然,在 64 位机器上,一切都会好起来的。
关于c - Bridge mac 学习老化时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21843258/