新聞中心
IPv6和IPv4同屬于網(wǎng)絡(luò)協(xié)議,在Linux系統(tǒng)中,IPv6和IPv4同時(shí)存在時(shí)可能會(huì)出現(xiàn)連接超時(shí)的情況,這時(shí)只需將IPv6禁用即可解決這個(gè)問(wèn)題,下面為大家詳細(xì)講解一下Linux下禁用IPv6具體方法。

查看IPv6在Linux中是否被啟用
所有現(xiàn)代Linux發(fā)行版默認(rèn)都自動(dòng)啟用IPv6。為了能看到IPv6在你的Linux中是否被激活,可以使用ifconfig或ip命令。如果你在輸入這些命令之后看到”inet6″字樣的輸出,那就意味著你的Linux系統(tǒng)啟用了IPv6。 $ ifconfig
$ ip addr
臨時(shí)禁用IPv6
如果你想要在你的Linux系統(tǒng)上臨時(shí)關(guān)閉IPv6,你可以用 /proc 文件系統(tǒng)?!迸R時(shí)”的意思是我們所做的禁用IPv6的更改在系統(tǒng)重啟后將不被保存。IPv6會(huì)在你的Linux機(jī)器重啟后再次被啟用。 要將一個(gè)特定的網(wǎng)絡(luò)接口禁用IPv6,使用以下命令:
$ sudo sh -c 'echo 1 > /proc/sys/net/ipv6/conf/ /disable_ipv6'
舉個(gè)例子,將eth0接口禁用IPv6:
$ sudo sh -c 'echo 1 > /proc/sys/net/ipv6/conf/eth0/disable_ipv6'
重新啟用eth0接口的IPv6:
$ sudo sh -c 'echo 0 > /proc/sys/net/ipv6/conf/eth0/disable_ipv6'
如果你想要將整個(gè)系統(tǒng)所有接口包括回環(huán)接口禁用IPv6,使用以下命令:
$ sudo sh -c 'echo 1 > /proc/sys/net/ipv6/conf/all/disable_ipv6'
永久禁用IPv6
以上方法是不能永久禁用IPv6的,你一旦重啟系統(tǒng)IPv6還是會(huì)被啟用。如果你想要永久關(guān)閉它,有幾個(gè)方法你可以試試。 方法一 第一種方法是通過(guò) /etc/sysctl.conf 文件對(duì) /proc 進(jìn)行永久修改。 換句話說(shuō),就是用文本編輯器打開(kāi) /etc/sysctl.conf 然后添加以下內(nèi)容:
# 禁用整個(gè)系統(tǒng)所有接口的IPv6
net.ipv6.conf.all.disable_ipv6 = 1
# 禁用某一個(gè)指定接口的IPv6(例如:eth0, lo)
net.ipv6.conf.lo.disable_ipv6 = 1
net.ipv6.conf.eth0.disable_ipv6 = 1
在 /etc/sysctl.conf 使這些更改生效,運(yùn)行以下命令:
$ sudo sysctl -p /etc/sysctl.conf
或者直接重啟。
方法二 另一個(gè)永久禁用IPv6的方法是在開(kāi)機(jī)的時(shí)候傳遞一個(gè)必要的內(nèi)核參數(shù)。 用文本編輯器打開(kāi) /etc/default/grub 并給GRUBCMDLINELINUX變量添加”ipv6.disable=1″。
$ sudo vi /etc/default/grub
GRUB_CMDLINE_LINUX="xxxxx ipv6.disable=1"
上面的”xxxxx”代表任何已有的內(nèi)核參數(shù),在它后面添加”ipv6.disable=1″。 最后,不要忘記用以下方法保存對(duì)GRUB/GRUB2的修改: Debian、Ubuntu或Linux Mint系統(tǒng):
$ sudo update-grub
Fedora、CentOS/RHEL系統(tǒng):
$ sudo grub2-mkconfig -o /boot/grub2/grub.cfg
現(xiàn)在只要你重啟你的Linux系統(tǒng),IPv6就會(huì)完全被禁用。
禁用IPv6之后的其它可選步驟
這里有一些在你禁用IPv6后需要考慮的可選步驟,這是因?yàn)楫?dāng)你在內(nèi)核里禁用IPv6后,其它程序也許仍然會(huì)嘗試使用IPv6。在大多數(shù)情況下,應(yīng)用程序的這種行為不太會(huì)影響到什么,但是出于效率或安全方面的原因,你可以為他們禁用IPv6。 /etc/hosts 根據(jù)你的設(shè)置, /etc/hosts 會(huì)包含一條或多條IPv6的hosts和它們的地址。用文本編輯器打開(kāi) /etc/hosts 并注釋掉包含IPv6 hosts的腳本行。
$ sudo vi /etc/hosts # comment these IPv6 hosts # ::1 ip6-localhost ip6-loopback # fe00::0 ip6-localnet # ff00::0 ip6-mcastprefix # ff02::1 ip6-allnodes # ff02::2 ip6-allrouters
Network Manager 如果你在用NetworkManager來(lái)管理你的網(wǎng)絡(luò)設(shè)置,你可以在NetworkManager里禁用IPv6。在NetworkManager打開(kāi)wired connection,點(diǎn)擊”IPv6 Settings”選項(xiàng)并在”Method”一欄選擇”Ignore”,保存退出。 201563173528661.png (473×489) SSH服務(wù) 默認(rèn)情況下,OpenSSH服務(wù)(sshd)會(huì)去嘗試?yán)塈Pv4和IPv6的地址。 要強(qiáng)制sshd只捆綁IPv4地址,用文本編輯器打開(kāi) /etc/ssh/sshd_config 并添加以下行。inet只適用于IPv4,而inet6是適用于IPv6的。
$ sudo vi /etc/ssh/sshd_config AddressFamily inet
然后重啟sshd服務(wù)。
當(dāng)前標(biāo)題:Linux中禁用IPv6
鏈接地址:http://m.fisionsoft.com.cn/article/cdhegip.html


咨詢
建站咨詢
