Network configuration (简体中文): Difference between revisions

From ArchWiki
(Redirect to zh-hans wiki.)
Tag: New redirect
 
(72 intermediate revisions by 20 users not shown)
Line 1: Line 1:
[[Category:Networking (简体中文)]]
#redirect [[zh-hans:Network configuration]]
[[cs:Network configuration]]
[[el:Network configuration]]
[[en:Network configuration]]
[[es:Network configuration]]
[[fr:Connexions reseau]]
[[it:Network configuration]]
[[ja:ネットワーク設定]]
[[nl:Network configuration]]
[[pt:Network configuration]]
[[ro:Configurare retea]]
[[ru:Network configuration]]
[[sk:Network configuration]]
[[tr:Ağ Yapılandırması]]
[[zh-tw:Network configuration]]
{{Related articles start (简体中文)}}
{{Related|Jumbo frames}}
{{Related|Firewalls}}
{{Related|Wireless network configuration (简体中文)}}
{{Related|List of applications#Network Managers}}
{{Related articles end}}
{{TranslationStatus (简体中文)|Network_configuration|2016-03-19|424907}}
本页解释了如何配置 '''有线''' 网络连接。如果你需要设置 '''无线''' 网络,参见[[Wireless network configuration (简体中文)|无线配置]]页面。
 
== 检查连接 ==
 
基本的安装过程已经创建了正确的网络配置。通过''ping''检查:
{{hc|$ ping -c 3 www.google.com|<nowiki>
PING www.l.google.com (74.125.224.146) 56(84) bytes of data.
64 bytes from 74.125.224.146: icmp_req=1 ttl=50 time=437 ms
</nowiki>}}
 
成功时会收到类似上面的 64 bytes 信息,按 {{ic|Control-C}} 可以停止ping.
 
{{小贴士| 参数  {{ic|-c 3}} 表示执行命令 {{ic|ping}} 3次 。 参见 {{ic|man ping}}。}}
 
如果上面的命令说 unknown hosts,意思是你的机器无法进行域名解析。这可能和你的服务提供商或者你的路由器/网关有关。你可以尝试 ping {{ic|8.8.8.8}} 来验证你的电脑是否能访问 Internet。它是 Google 的主 DNS 服务器,因此它可以视为可信的,通常不会被过滤系统或代理屏蔽。
 
{{hc|$ ping -c 3 8.8.8.8|<nowiki>
PING 8.8.8.8 (8.8.8.8) 56(84) bytes of data.
64 bytes from 8.8.8.8: icmp_req=1 ttl=53 time=52.9 ms
</nowiki>}}
 
如果可以 ping {{ic|8.8.8.8}} 但是不能 ping {{ic|www.google.com}}, 参考 [[resolv.conf]] 检查 DNS 配置。还需要查下 {{ic|/etc/nsswitch.conf}} 中的  {{ic|hosts}} 行。如果不能 ping 通,请检查网线问题。
 
== 设置计算机名 ==
 
[[Wikipedia:Hostname|主机名]] 是一个网络中唯一标识一台机器的名称。主机名通过文件 {{ic|/etc/hostname}} 进行配置。这样设置主机名:
 
# hostnamectl set-hostname '''myhostname'''
 
这将会把 '''myhostname''' 写入 {{ic|/etc/hostname}}。详情参见 {{ic|man 5 hostname}} 和 {{ic|man 1 hostnamectl}}。
 
建议同时在 {{ic|/etc/hosts}} 中设置 hostname:
 
{{hc|/etc/hosts|2=
#
# /etc/hosts: static lookup table for host names
#
#<ip-address> <hostname.domain.org> <hostname>
127.0.0.1 localhost.localdomain localhost ''myhostname''
::1 localhost.localdomain localhost ''myhostname''
}}
 
{{注意|{{Pkg|systemd}} 通过 {{ic|myhostname}} nss 模块(在 {{ic|/etc/nsswitch.conf}} 中默认启用)进行主机名解析,所以大部分情况下都不需要在 {{ic|/etc/hosts}} 中设置主机名。但是有些用户反馈如果不设置,某些依赖网络的程序会碰到延迟问题。参考 [[#Local network hostname resolution]]。}}
 
要临时设置主机名(直到下次重启为止),使用 {{Pkg|inetutils}} 中的 {{ic|hostname}} 命令:
 
# hostname ''myhostname''
 
== 设备驱动程序 ==
 
=== 检测驱动状态 ===
 
[[Udev]] 会探测网卡([[Wikipedia:Network_interface_controller|NIC]])并在启动时自动载入必要的模块。 检查 {{ic|lspci -v}} 输出中 "Ethernet controller" (或者类似的)条目,它会告诉你哪个内核模块包含了网络设备的驱动程序。例如:
 
{{hc|$ lspci -v|
02:00.0 Ethernet controller: Attansic Technology Corp. L1 Gigabit Ethernet Adapter (rev b0)
...
Kernel driver in use: atl1
Kernel modules: atl1
}}
 
接下来, 用 {{ic|dmesg <nowiki>|</nowiki> grep ''module_name''}} 来检查是否已经加载了驱动。例如:
$ dmesg |grep atl1
  ...
  atl1 0000:02:00.0: eth0 link is up 100 Mbps full duplex
 
如果驱动加载成功,就跳过下一节,否则,你需要知道您特定型号的网络设备需要哪一个模块。
 
=== 加载设备模块 ===
 
用 Google 查找芯片组需要的模块/驱动。常见的驱动模块有用于 Realtek 芯片组网卡的 {{ic|8139too}},或者用于 Sis 芯片组网卡的 {{ic|sis900}}。知道要使用什么模块之后,尝试 [[Kernel modules#Manual module handling|手动加载它]]。如果你碰到了未找到模块的错误,可能驱动没有包括在 Arch 的内核中。你可以在 [[AUR]] 中搜索模块名称。
 
如果 udev 在引导时不能自动侦测和加载适当的模块,参见 [[Kernel modules#Loading]]。
 
== 网络接口 ==
 
=== 设备命名 ===
 
对于有多块网卡的电脑,固定的设备名称很重要。许多配置问题都是由于网络接口名称变化引起的。
 
[[udev]] 负责给设备命名。Systemd v197 引入了[http://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames 可预测的网络接口名称]自动给网络设备分配静态名称,网络接口现在是以前缀 {{ic|en}}(以太网)、{{ic|wl}}(WLAN)、或者 {{ic|ww}}(WWAN)附上一个自动生成的标识符,产生了一个类似于 {{ic|enp0s25}} 的条目。在 [[kernel parameters]] 中添加 {{ic|1=net.ifnames=0}} 可以禁用此功能.
 
{{注意|当你改变接口命名规则时,不要忘记更新所有与网络相关的配置文件和自定义的 systemd unit 文件以反映变化。特别是当你启用了 [[netctl#Basic method|netctl 静态配置]] 时,要运行 {{ic|netctl reenable ''profile''}} 来更新生成的服务文件。}}
 
=== 获取当前网络名 ===
 
可以通过 sysfs 或 {{ic|ip link}} 找到。
 
{{hc|$ ls /sys/class/net|
lo eth0 eth1 firewire0
}}
 
{{hc|$ ip link|
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: enp0s3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP mode DEFAULT group default qlen 1000
    link/ether 08:00:27:23:6f:3a brd ff:ff:ff:ff:ff:ff
}}
无线设备名称也可以通过 {{ic|iw dev}} 查看,请参考 [[Wireless network configuration#Getting some useful information]].
 
==== 更改设备名称 ====
 
你可以用 udev-rule 手动定义名称来更改设备名称。例如:
 
{{hc|/etc/udev/rules.d/10-network.rules|<nowiki>
SUBSYSTEM=="net", ACTION=="add", ATTR{address}=="aa:bb:cc:dd:ee:ff", NAME="net1"
SUBSYSTEM=="net", ACTION=="add", ATTR{address}=="ff:ee:dd:cc:bb:aa", NAME="net0"
</nowiki>}}
 
值得注意的两点:
 
* 使用这条命令来获得每张网卡的 MAC 地址:{{ic|cat /sys/class/net/'''设备名'''/address}}
* 确保你的 udev 规则中使用小写的十六进制值,而不是大写。
 
{{注意|选择静态名称时,'''应该避免使用形如 "eth''X''" 或 "wlan''X''" 的名称''',因为这可能在引导时导致内核与 udev 之间的竞争状态。相反,最好用内核默认不会使用的接口名称,例如:{{ic|net0}}、{{ic|net1}}、{{ic|wifi0}}、{{ic|wifi1}}。更多细节请查看 [http://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames systemd] 文档。}}
 
==== 使用传统网络命名规则 ====
 
如果希望使用传统的命名方法 eth0,可以通过下面方法禁用 [http://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames Predictable Network Interface Names]:
 
# ln -s /dev/null /etc/udev/rules.d/80-net-setup-link.rules
 
=== 设定设备的 MTU 和队列长度 ===
 
你可以手动定义一条 udev 规则来改变队列的 MTU(最大传输单元)和队列长度You can change the device MTU and queue length by defining manually with an udev-rule。举例来说:
 
{{hc|/etc/udev/rules.d/10-network.rules|<nowiki>
ACTION=="add", SUBSYSTEM=="net", KERNEL=="wl*", ATTR{mtu}="1480", ATTR{tx_queue_len}="2000"
</nowiki>}}
 
=== 启用和禁用网络接口 ===
 
可以通过如下命令启用或禁用接口:
 
# ip link set eth0 up
# ip link set eth0 down
 
查看结果:
 
{{hc|$ ip link show dev eth0|
2: eth0: <BROADCAST,MULTICAST,PROMISC,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master br0 state UP mode DEFAULT qlen 1000
...
}}
 
{{Note| 如果默认路由是通过 {{ic|eth0}} 建立,禁用接口同时也会删除路由,再次启用也不会自动重新建立路由,要重新建立,请参考 [[#手动分配]].}}
 
== 配置 IP 地址 ==
 
有两种配置方式:通过 [[Wikipedia:Dynamic Host Configuration Protocol|DHCP]],或者不变的''静态''地址。
 
{{Tip| In addition to the methods described below one can also use a [[List of applications#Network managers|network manager]]. Network managers are especially useful for dynamic network connections and wifi networking.}}
 
=== 动态 IP 地址 ===
 
==== systemd-networkd ====
一种DHCP的简单配置方法是利用systemd提供的[[systemd-networkd]]服务。参见[[systemd-networkd#Basic DHCP network]]。
 
==== dhcpcd ====
[[dhcpcd]] is the default client in Arch Linux to setup DHCP on the installation ISO. It is a powerful tool with many configurable DHCP client options. See [[dhcpcd#Running]] on how to activate it for an interface.
 
==== netctl ====
 
[[netctl]]是利用用户创建的profiles进行网络配置的CTI-based工具,如何创建profile参见[[netctl#Example profiles]],激活参见[[netctl#Basic method]]。
 
=== 静态 IP 地址 ===
 
不管用什么方法设置静态 IP,都需要确定:
 
* 静态IP地址,
* [[Wikipedia:Subnetwork|子网掩码]],使用 [[Wikipedia:CIDR_notation|CIDR 表示法]]
* Subnet mask in [[wikipedia:Classless Inter-Domain Routing#CIDR notation|CIDR notation]], for example {{ic|/24}} is the CIDR notation of {{ic|255.255.255.0}} netmask
* [[Wikipedia:Broadcast_address|广播地址]],
* [[Wikipedia:Default_gateway|网关]]的IP地址
* Name server (DNS) IP addresses. See also [[resolv.conf]].
 
如果你想配置一个内部网络,可以将你的 IP 设置成 192.168.*.* ,子网掩码设置成 255.255.255.0 ,广播地址设置成 192.168.*.255 。网关通常是 192.168.*.1 或者 192.168.*.254。
 
{{Warning|
* Make sure manually assigned IP addresses do not conflict with DHCP assigned ones. See [http://www.raspberrypi.org/forums/viewtopic.php?f&#61;28&t&#61;16797 this forum thread]
* 在不使用路由器的情况下和一台安装 Windows 的电脑分享你的网络连接,请确保两台电脑都使用静态 IP ,否则你的局域网将会有问题。
}}
 
==== netctl ====
To create a [[netctl]] profile with a static IP, set the {{ic|1=IP=static}} option as well as {{ic|Address}}, {{ic|Gateway}}, and {{ic|DNS}}. See [[netctl#Wired]].
 
==== systemd-networkd ====
 
The [[systemd-networkd]] service provided by systemd can set up a static IP using a simple configuration file. See [[systemd-networkd#Wired adapter using a static IP]].
 
==== dhcpcd ====
 
See [[dhcpcd#Static profile]].
 
==== 手动指定 ====
 
It is possible to manually set up a static IP using only the {{pkg|iproute2}} package. This is a good way to test connection settings since the connection will not persist across reboots. First enable the [[#Network interfaces|network interface]]:
 
  # ip link set ''interface'' up
 
在终端中指定一个静态 IP:
 
# ip addr add ''IP_address''/''subnet_mask'' broadcast ''broadcast_address'' dev ''interface''
 
如此添加你的网关(用你的网关 IP 替换):
 
# ip route add default via <默认网关的 IP 地址>
 
例如:
# ip link set eth0 up
# ip addr add 192.168.1.2/24 dev eth0
# ip route add default via 192.168.1.1
 
To undo these steps (e.g. before switching to a dynamic IP), first remove any assigned IP address:
# ip addr flush dev ''interface''
 
然后删除指定的网关:
# ip route flush dev ''interface''
 
最后禁用接口:
# ip link set ''interface'' down
 
更多选项参见:{{ic|man ip}},这些命令可以用 systemd 服务自动启动,请参考[[systemd#Writing unit files|systemd units]].
 
==== 计算地址 ====
 
可以用 {{Pkg|ipcalc}} 软件包提供的 {{ic|ipcalc}} 工具自动计算 IP 广播、子网掩码、主机范围等。例如通过火线连接视窗系统主机到 Arch。为了安全和网络组织,将它们分到独立的网络中,然后配置子网掩码和广播地址,网络中只有2台主机。要找出掩码和广播地址,我使用了 ipcalc,提供了它 arch firewire nic 的 IP 地址10.66.66.1,并告诉 ipcalc 要建立一个只有2台主机的网络。
 
{{hc|$ ipcalc -nb 10.66.66.1 -s 1|<nowiki>
Address:  10.66.66.1
 
Netmask:  255.255.255.252 = 30
Network:  10.66.66.0/30
HostMin:  10.66.66.1
HostMax:  10.66.66.2
Broadcast: 10.66.66.3
Hosts/Net: 2                    Class A, Private Internet
</nowiki>}}
 
== 更多设置 ==
 
=== 笔记本电脑使用 Ifplugd ===
 
{{Tip|[[dhcpcd]] 也提供了同样的功能。}}
 
[[官方仓库]] 中的 {{Pkg|ifplugd}} 是一个守护进程,当网络适配器插入的时候自动配置网络,当网络断开的时候自动取消配置(比如某些3G的usb网络适配器)。这对于笔记本电脑这样的使用移动式的网络适配器的情况很有用,因为他只会在网络实际接入的时候才会配置网络接口。另外一个可能会用得着它的情况是,你需要重启你的网络,可是你既不想重启电脑也不想在 shell 中配置。
 
在默认情况下,它会检查 {{ic|eth0}} 设备。要更改这个设置(以及更改其他设置,比如等待时间),可以编辑 {{ic|/etc/ifplugd/ifplugd.conf}}。
 
启用 {{ic|net-auto-wired.service}} 就会在开机时启动 ifplugd,否则,你可以使用 {{ic|ifplugd@eth0.service}}。
{{注意|[[Netctl]] 软件包包含了 {{ic|netctl-ifplugd@.service}},否则你可以使用 {{Pkg|ifplugd}} 软件包中的 {{ic|ifplugd@.service}}。例如 {{ic|systemctl enable ifplugd@eth0.service}}。}}
 
=== 绑定和链路聚合 ===
 
参见 [[netctl (简体中文)#Bonding(绑定)]] 或 [[Wireless bonding]].
 
=== IP 别名 ===
 
IP 别名是指给同一个网络接口分配多个 IP 地址。这样一个网络节点可以有多个网络连接,每个实现不同的作用。Typical uses are virtual hosting of Web and FTP servers, or reorganizing servers without having to update any other machines (this is especially useful for nameservers).
 
要手动设置别名,可以使用 {{Pkg|iproute2}} 执行:
 
# ip addr add 192.168.2.101/24 dev eth0 label eth0:1
 
要删除别名:
 
# ip addr del 192.168.2.101/24 dev eth0:1
 
发送到一个子网的软件不会使用主别名,如果目标 IP 属于子别名,原始 IP 也会被相应设置。如果有多个网卡,可以通过  {{ic|ip route}} 查看默认路由。
 
=== 更改 MAC/硬件地址 ===
 
参见 [[MAC address spoofing|伪造 MAC 地址]]。
 
=== 共享网络连接 ===
 
参见 [[Internet sharing|共享网络连接]]。
 
=== 路由配置 ===
 
参见 [[Router|路由]]。
 
=== 局域网主机的名称解析 ===
 
首先需要设置好主机名。
 
{{hc|$ ping ''myhostname''|2=
PING myhostname (192.168.1.2) 56(84) bytes of data.
64 bytes from myhostname (192.168.1.2): icmp_seq=1 ttl=64 time=0.043 ms}}
 
如果希望其他机器通过主机名访问到这台机器,可以手动修改 {{ic|/etc/hosts}} 文件或通过一个服务解析此主机名。使用 systemd 时,主机名解析可以通过 {{ic|myhostname}} nss 模块提供。但是并不是所有的网络服务都被支持 (例如: [https://bbs.archlinux.org/viewtopic.php?id=176761], [https://bbs.archlinux.org/viewtopic.php?id=186967]),或者其它客户端使用不同的操作系统解析主机名,这个也无法被 systemd 支持。
 
第一个解决方法是修改 {{ic|/etc/hosts}}:
 
127.0.1.1 ''myhostname''.localdomain ''myhostname''
 
这样系统可以同时解析两个主机名:
$ getent hosts
127.0.0.1      localhost
127.0.1.1      myhostname.localdomain myhostname
 
如果使用固定 IP 地址,请用 IP 地址替换 {{ic|127.0.1.1}}.
 
还有一个方法是架设 DNS 服务器例如 [[BIND]] or [[Unbound]], 但是这些方法有点小提大作。小的网络可以使用  [[Wikipedia:Zero-configuration_networking|zero-configuration networking]] 服务。有两个选择:
 
*[[Samba]] 通过 Microsoft's '''NetBIOS''' 提供主机名称解析。这只需要安装 {{Pkg|samba}} 并启用 {{ic|nmbd.service}} 服务。运行 Windows、 OS X、或者运行着 {{ic|nmbd}} 的 Linux,将能找到你的机器。
 
*[[Avahi]] 通过 '''zeroconf''',提供主机名称解析, 它也被称称作 Avahi 或者 Bonjour。这需要比 Samba 再稍微复杂一点的配置:详细信息参见 [[Avahi#Hostname resolution]]。运行 OS X 的电脑,或者运行着 Avahi 守护进程的 Linux,将能找到你的机器。Windows 没有内置的 Avahi 客户端或者守护进程。
 
=== 全接收模式 ===
 
切换网卡到 [[wikipedia:Promiscuous_mode|全接收模式]] 可以让网卡接收所有数据然后转交给操作系统处理。而正常模式下,网卡会丢掉不是不发给自己的数据。通常用来检查网络问题或进行 [[wikipedia:Packet_sniffing|数据包嗅探]].
 
{{hc|/etc/systemd/system/promiscuous@.service|<nowiki>
[Unit]
Description=Set %i interface in promiscuous mode
After=network.target
 
[Service]
Type=oneshot
ExecStart=/usr/bin/ip link set dev %i promisc on
RemainAfterExit=yes
 
[Install]
WantedBy=multi-user.target
</nowiki>}}
 
如果要在 {{ic|eth0}} 上启用全接收模式,只需要 [[enable|启用]] {{ic|promiscuous@eth0.service}}.
 
== 疑难排解 ==
 
=== 更换了连接cable modem的计算机 ===
 
许多家庭有线电视的运营商(例如加拿大最大的有线电视公司Videotron,还有中国大陆的有线电视宽带公司)都使用记录网卡MAC地址的方法将cable modem配置为只能一台计算机使用。一旦cable modem获得第一台连接它的PC的MAC地址,就不会响应任何其它MAC地址。这样如果你换了台PC(或者路由器),由于新PC(或者路由器)的MAC地址和旧的不同,就没法连接cable modem了。这时候必须复位cable modem以使它重新辨认新的PC。 你得关闭cable modem电源,然后重新打开。一旦cable modem重启并再次登录在线完毕(指示灯熄灭),重启新连接的PC以使它发起一个DHCP请求,或者手动发起DHCP请求。
 
如果这个方法不能奏效,你需要克隆原来机器上的MAC地址。参见 [[Configuring Network#Change MAC/hardware address|Change MAC/hardware address]]。
 
=== TCP窗口扩缩(window scaling)故障 ===
 
TCP包头有个窗口(window)值表明其它主机可以发送多少数据回来。这个值只有16个bit,也就是说窗口打消最多只有64Kb。TCP包会被缓存一段时间(得被记录),如果内存限制(过去经常是)的话,主机很容易会用完内存。
 
回到1992年,内存逐渐增加,[http://www.faqs.org/rfcs/rfc1323.html RFC 1323]被发布以改善情况:窗口扩缩(Window Scaling)。所有包里的窗口值,可以被初始连接时定义的一个缩放因子(Scale Factor)所改变。
 
8-bit的缩放因子使得窗口可以是初始64Kb的32倍。
 
但是Internet上有些有故障的路由器和防火墙会将缩放因子重写为0,这导致主机之间产生误解。
 
Linux内核2.6.17引入了新的计算方式生成更高的缩放因子,间接的使得这些有故障的路由器和防火墙引发的后果更明显。
 
这导致连接缓慢甚至中断。
 
==== 如何诊断故障 ====
 
首先,我们要明白:这个问题很怪异。在某些案例中,你根本无法使用(HTTP, FTP, ...),而有时候,你可以连接某些主机(很少)。
 
当你碰到这个故障时,{{ic|dmesg}}的输出正确,日志也没问题,{{ic|ip a}}报告状态正常&mdash; 实际上一切都正常。
 
如果你无法浏览任何网站,不过你能ping通少部分主机,很可能你是遇到了这个问题。:ping使用ICMP协议所以不受TCP问题的影响。
 
你可以尝试使用WireShark。你也许会看到UDP和ICMP通讯成功,但是TCP通讯不成功(仅对外国主机)。
 
==== 如何修复(糟糕的方法) ====
 
用比较糟糕的方法修复的话,你可以修改缩放因子计算所基于的tcp_rmem值。虽然它对大部分主机有效,但并不担保一定都有效,特别是某些很远的主机。
 
# echo "4096 87380 174760" > /proc/sys/net/ipv4/tcp_rmem
 
==== 如何修复(好点的方法) ====
 
只需要禁止窗口缩放。虽然窗口缩放是个不错的TCP特性,但它也可能令人不安,特别是当你没法修改除了问题的路由器的时候。有几种方法可以禁止窗口缩放,而看来最可靠的(适用于大部分内核)将下面一行加入到你的{{ic|/etc/sysctl.d/99-disable_window_scaling.conf}} 中 (见 [[sysctl]])
net.ipv4.tcp_window_scaling = 0
 
==== 如何修复(最佳的方法) ====
 
这个故障是由有毛病的路由器/防火墙引致的,所以最好换了它。有些用户报告说那些有故障的路由是他们自己的DSL路由。
 
==== 更多 ====
 
本段内容是基于LWN文章[http://lwn.net/Articles/92727/ TCP window scaling and broken routers]和一个Kernel Trap 文章:[http://kerneltrap.org/node/6723 Window Scaling on the Internet]。
 
在LKML上也有几篇相关的帖子。
 
=== Realtek 没有连接/网络唤醒故障 ===
 
使用基于Realtek 8168 8169 8101 8111芯片网卡(独立网卡和板载)的用户也许会发现这个故障,启动时网卡不可用,网卡上的连接指示灯不亮。这通常会发生在安装了Windows的双启动系统上。在windows下使用realtek官方驱动(2007年5月后的版本)会引发故障。新驱动通过在Windows关机时禁止网卡来关闭网络唤醒功能,直到下一次Windows启动前网卡都会一直不可用。通过观察连接指示灯在Windows启动前一直熄灭,而Windows关机时也会熄灭,你可以发现它。正常操作应该是只要系统一直开着,即使在POST加电过程中,连接指示灯也应该一直亮着的。这个故障也会影响其它没有安装新驱动的操作系统(例如Live CD等)。这里给出几种解决方案:
 
==== 在 Linux 中启用网卡 ====
 
参考上面的启用和禁用网络接口段落。
 
==== 方法一 还原/变更Win驱动 ====
 
你可以将你的Windows网卡驱动还原回Microsoft自带的驱动(如果有的话),或者安装2007年5月份以前的Realtek官方驱动(也许在网卡附带的CD上)。
 
==== 方法二 启动Windows驱动里的网络唤醒功能 ====
 
也许最好最快的修复方法就是改变Windows驱动里的这个设置。这个方法可以解决很多其它操作系统而不仅仅是Arch的麻烦。在Windows的设备管理器里,找到你的Realtek网卡,双击它。在“高级”标签页中,开启"wake-on-lan after shutdown"选项。
 
  例如在Windows XP里
  右键点击我的电脑-->管理-->设备管理器-->网络适配器-->双击 Realtek ... --> 高级标签页--> Wake-On-Lan After Shutdown --> 启用。
 
{{注意|新的 Realtek Windows 驱动程序中(已测试了 2009/01/22 GIGABYTE 上的 ''Realtek 8111/8169 LAN Driver v5.708.1030.2008'')可能与这里的选项稍微有点不同,像 ''Shutdown Wake-On-LAN --> Enable''。似乎把它切换成 {{ic|Disable}} 没有效果(你仍然可以在Windows关闭时看到连接指示灯熄灭)。一个比较不好的解决方法是引导 Windows,然后立即重启系统(执行非正常重启/关机),不给予 Windows 驱动程序关闭 LAN 的机会。连接指示灯将会保持亮着,网卡也会在 POST 之后保持可用 - 直到你再次进入 Windows 并正常关机。}}
 
==== 方法三 更新Realtek Linux驱动 ====
 
可以在realtek的官方网页上找到新的Linux驱动。(没有测试过,不过相信也能解决问题)。
 
==== 方法四 在 BIOS/CMOS 中启用 ''LAN Boot ROM'' ====
 
尽管 Windows 驱动程序在系统关闭时禁用了它,但在 BIOS/CMOS 中设置 ''Integrated Peripherals --> Onboard LAN Boot ROM --> Enabled'',系统启动时会重新激活 Realtek LAN 芯片。
{{注意|这个方法多次在 GIGABYTE GA-G31M-ES2L 主板,2009/02/05 发布的 BIOS 版本 F8 上测试成功。YMMV。}}
 
=== 检查 DHCP 问题先释放 IP 地址 ===
 
当 DHCP 获得了错误的 IP 分配就可能产生这个问题。举例来说,当两个路由器通过VPN相连,通过VPN与我相连的路由器可能分配IP地址。要修复这个问题,在终端中以 root 权限释放 IP 地址:
 
# dhcpcd -k
 
然后请求一个新的地址:
 
# dhcpcd
 
可能你必须运行这两个命令好几次。
 
=== Atheros 芯片组找不到网卡 ===
 
有些用户的 Atheros 芯片无法正常工作 (至少在 2014.2 月的安装中). 可以通过安装 {{AUR|backports-patched}} 解决。
 
=== Broadcom BCM57780 ===
 
这个 Broadcom 芯片只有你指定模块的加载顺序后才能正常工作。这些模块是 {{ic|broadcom}} 和 {{ic|tg3}},前者需要首先加载。
 
如果你的电脑有这个芯片,这些步骤应该有用:
 
$ lspci | grep Ethernet
02:00.0 Ethernet controller: Broadcom Corporation NetLink BCM57780 Gigabit Ethernet PCIe (rev 01)
 
如果你的有线网络不能工作,尝试断开网线,然后以 root 权限实施以下步骤:
 
# modprobe -r tg3
# modprobe broadcom
# modprobe tg3
 
现在接入网线。如果现在你的故障解决了,你可以把 {{ic|broadcom}} 和 {{ic|tg3}} (以此顺序)加入到 {{ic|/etc/mkinitcpio.conf}} 的 {{ic|MODULES}} 一行,使得变更持久化:
 
MODULES=".. broadcom tg3 .."
 
然后重新编译 initramfs:
 
# mkinitcpio -p linux
 
* 还有一种方法是创建 {{ic|/etc/modprobe.d/broadcom.conf}}:
  softdep tg3 pre: broadcom
 
{{注意|这些方法可能也适用于其它芯片,例如 BCM57760。}}
 
=== Realtek RTL8111/8168B ===
 
{{hc|<nowiki># lspci | grep Ethernet</nowiki>|
03:00.0 Ethernet controller: Realtek Semiconductor Co., Ltd. RTL8111/8168B PCI Express Gigabit Ethernet controller (rev 02)
}}
 
The adapter should be recognized by the {{ic|r8169}} module. However, with some chip revisions the connection may go off and on all the time. The alternative {{Pkg|r8168}} can be found in the [[official repositories]] and should be used for a reliable connection in this case. [[Kernel_modules#Blacklisting|Blacklist]] {{ic|r8169}}, if {{Pkg|r8168}} is not automatically loaded by [[udev]] add it to your list of user specified [[Kernel_modules#Loading|modules]].
 
{{Accuracy|"some revisions", no proof the driver is the cause, and not e.g poorly configured DNS servers}}
 
Another fault in the drivers for some revisions of this adapter is poor IPv6 support. [[IPv6#Disable functionality]] can be helpful if you encounter issues such as hanging webpages and slow speeds.
 
=== Gigabyte Motherboard with Realtek 8111/8168/8411 ===
With motherboards such as the Gigabyte GA-990FXA-UD3, booting with IOMMU off (which can be the default) will cause the network interface to be unreliable, often failing to connect or connecting but allowing no throughput. This will apply not only to the onboard NIC, but any other pci-NIC you put in the box because the IOMMU setting affects the entire network interface on the board. Enabling IOMMU and booting with the install media will throw AMD I-10/xhci page faults for a second, but then boot normally, resulting in a fully functional onboard NIC (even with the r8169 module).
 
When configuring the boot process for your installation, add {{ic|1=iommu=soft}} as a [[kernel parameter]] to eliminate the error messages on boot and restore USB3.0 functionality.

Latest revision as of 02:42, 4 December 2022