linux – 使用radvd发布子网路由

前端之家收集整理的这篇文章主要介绍了linux – 使用radvd发布子网路由前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我们建立了一个小型的IPv6测试网络.设置如下所示:
::/0
+----------+
| Firewall | Router to the public net
+----------+
     |           2001:...::/106
     |       +----------+
     +-------|  SIT GW  | sit Tunnel gatway to the some test users
     |       +----------+
     |
+----------+
| Test Sys |  Testsystem
+----------+

我们的想法是从防火墙发布默认路由,并从sit网关发布SIT子网的路由. radvd的配置是:

# Firewall
interface eth0
{
   AdvSendAdvert on;
   route ::/0 
   {
   };
};


# SIT Gatway
interface eth0
{
   AdvSendAdvert on;
   route 2001:...::/106
   {
   };
};

我们抓住了副词.使用tcpdump的包和包看起来不错.我们看到来自fw的默认路由,以及来自SIT gatway的子网路由.

但是,如果我们查看测试系统,则两个网关上都有两条默认路由.没有子网路由.路由当然不起作用.在这里我们得到的路线:

2001:.....::/64 dev eth0  proto kernel  metric 256  mtu 1500 advmss 1440 hoplimit 4294967295
fe80::/64 dev eth0  proto kernel  metric 256  mtu 1500 advmss 1440 hoplimit 4294967295
default via fe80::baac:6fff:fe8e:XXXX dev eth0  proto kernel  metric 1024  expires 0sec mtu 1500 advmss 1440 hoplimit 64
default via fe80::e415:aeff:fe12:XXXX dev eth0  proto kernel  metric 1024  expires 0sec mtu 1500 advmss 1440 hoplimit 64

任何的想法?

解决方法

我发现了这个问题.

默认情况下,Linux内核仅通过icmpv6中的路由器通告选项接受默认路由.

解决此问题,必须设置正确的内核参数:

net.ipv6.conf.all.accept_ra_rt_info_max_plen = 128

来自内核文档:

accept_ra_rt_info_max_plen – INTEGER
Maximum prefix length of Route Information in RA.

06001

猜你在找的Linux相关文章