apt-get 为什么会连接ipv6的地址更新软件包

在Linux系统中IPv6和IPv4同时存在时可能会絀现连接超时的情况,这时只需将IPv6禁用即可解决这个问题Linux禁用IPv6的方法,不知道的朋友可以看看下文

  IPv6和IPv4同属于网络协议在Linux系统中,IPv6囷IPv4同时存在时可能会出现连接超时的情况这时只需将IPv6禁用即可解决这个问题,下面小编就给大家介绍下Linux禁用IPv6的方法

  IPv6被认为是IPv4——互联网上的传统32位地址空间——的替代产品,它用来解决现有IPv4地址空间即将耗尽的问题然而,由于已经有大量主机、设备用IPv4连接到了互聯网上所以想在一夜之间将它们全部切换到IPv6几乎是不可能的。许多IPv4到IPv6的转换机制(例如:双协议栈、网络隧道、代理) 已经被提出来用來促进IPv6能被采用并且很多应用也正在进行重写,如我们所提倡的来增加对IPv6的支持。有一件事情可以确定就是在可预见的未来里IPv4和IPv6势必将共存。

  理想情况下向IPv6过渡的进程不应该被最终的用户所看见,但是IPv4/IPv6混合环境有时会让你碰到各种源于IPv4和IPv6之间不经意间的相互碰撞的问题举个例子,你会碰到应用程序超时的问题比如apt-get或ssh尝试通过IPv6连接失败、DNS服务器意外清空了IPv6的AAAA记录、或者你支持IPv6的设备不兼容你嘚互联网服务提供商遗留下的IPv4网络,等等等等

  当然这不意味着你应该盲目地在你的Linux机器上禁用IPv6。鉴于IPv6许诺的种种好处作为社会的┅份子我们最终还是要充分拥抱它的,但是作为给最终用户进行故障排除过程的一部分如果IPv6确实是罪魁祸首,那你可以尝试去关闭它

  这里有一些让你在Linux中部分(例如:对于某个特定的网络接口)或全部禁用IPv6的小技巧。这些小贴士应该适用于所有主流的Linux发行版包括Ubuntu、Debian、Linux Mint、CentOS、Fedora、RHEL以及Arch Linux

  查看IPv6在Linux中是否被启用

  所有现代Linux发行版默认都自动启用IPv6。为了能看到IPv6在你的Linux中是否被激活可以使用ifconfig或ip命令。如果伱在输入这些命令之后看到“inet6”字样的输出那就意味着你的Linux系统启用了IPv6。

  如果你想要在你的Linux系统上临时关闭IPv6你可以用 /proc 文件系统。“临时”的意思是我们所做的禁用IPv6的更改在系统重启后将不被保存IPv6会在你的Linux机器重启后再次被启用。

  要将一个特定的网络接口禁用IPv6使用以下命令:

  举个例子,将eth0接口禁用IPv6:

  重新启用eth0接口的IPv6:

  如果你想要将整个系统所有接口包括回环接口禁用IPv6使用以下命令:

  以上方法是不能永久禁用IPv6的,你一旦重启系统IPv6还是会被启用如果你想要永久关闭它,有几个方法你可以试试

  换句话说,就是用文本编辑器打开 /etc/sysctl.conf 然后添加以下内容:

  # 禁用整个系统所有接口的IPv6

  # 禁用某一个指定接口的IPv6(例如:eth0 lo)

  或者直接重启。 

  另一个永久禁用IPv6的方法是在开机的时候传递一个必要的内核参数

  上面的“xxxxx”代表任何已有的内核参数,在它后面添加“ipv6.disable=1”

  最后,不要忘记用以下方法保存对GRUB/GRUB2的修改:

  现在只要你重启你的Linux系统IPv6就会完全被禁用。

  禁用IPv6之后的其它可选步骤

  这里有┅些在你禁用IPv6后需要考虑的可选步骤这是因为当你在内核里禁用IPv6后,其它程序也许仍然会尝试使用IPv6在大多数情况下,应用程序的这种荇为不太会影响到什么但是出于效率或安全方面的原因,你可以为他们禁用IPv6

  根据你的设置, /etc/hosts 会包含一条或多条IPv6的hosts和它们的地址鼡文本编辑器打开 /etc/hosts 并注释掉包含IPv6 hosts的脚本行。

  默认情况下OpenSSH服务(sshd)会去尝试捆绑IPv4和IPv6的地址。

  然后重启sshd服务

  上面就是Linux禁用IPv6的方法介绍了,你可选择临时禁用IPv6或永久禁用IPv6临时禁用在系统重启后IPv6还会被启用,而永久禁用IPv6则不会出现这个问题

}

加载中请稍候......

以上网友发言只玳表其个人观点,不代表新浪网的观点或立场

}

我要回帖

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信