networkd.xml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
  3. "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
  4. <!ENTITY % general-entities SYSTEM "../general.ent">
  5. %general-entities;
  6. ]>
  7. <sect1 id="ch-scripts-network" revision="systemd">
  8. <?dbhtml filename="network.html"?>
  9. <title>一般网络配置</title>
  10. <indexterm zone="ch-scripts-network">
  11. <primary sortas="d-network">network</primary>
  12. <secondary>configuring</secondary></indexterm>
  13. <para>本节只适用于需要配置网卡的情况。</para>
  14. <sect2>
  15. <title>网络接口配置文件</title>
  16. <para>从 209 版本开始,systemd 提供一个名为
  17. <command>systemd-networkd</command> 的网络配置守护进程,
  18. 它能够用于基础网络配置。另外,自 213 版本起,可以用
  19. <command>systemd-resolved</command> 代替静态
  20. <filename>/etc/resolv.conf</filename> 文件处理域名解析。
  21. 这两个服务在默认情况下都是启用的。</para>
  22. <para><command>systemd-networkd</command> (以及
  23. <command>systemd-resolved</command>)的配置文件可以放置在
  24. <filename class="directory">/usr/lib/systemd/network</filename>
  25. 或 <filename class="directory">/etc/systemd/network</filename> 中。
  26. <filename class="directory">/etc/systemd/network</filename>
  27. 中的配置文件优先级高于
  28. <filename class="directory">/usr/lib/systemd/network</filename>
  29. 中的配置文件。有三种类型的配置文件:
  30. <filename class="extension">.link</filename>、
  31. <filename class="extension">.netdev</filename> 和
  32. <filename class="extension">.network</filename> 文件。
  33. 要获得它们的详细描述和内容示例,参阅
  34. the <filename>systemd-link(5)</filename>、
  35. <filename>systemd-netdev(5)</filename> 和
  36. <filename>systemd-network(5)</filename> man 手册页面。</para>
  37. <sect3 id="systemd-network-devices">
  38. <title>网络设备命名</title>
  39. <!--para>
  40. Udev normally assigns network card interface names based
  41. on system physical characteristics such as enp2s1. If you are
  42. not sure what your interface name is, you can always run
  43. <command>ip link</command> after you have booted your system.
  44. </para-->
  45. <para>
  46. Udev 一般根据系统物理特征为网卡分配接口名,例如 enp2s1。
  47. 如果您不确定接口名是什么,可以在引导您的系统后,
  48. 运行 <command>ip link</command> 命令。
  49. </para>
  50. <!--para>
  51. For most systems, there is only one network interface for
  52. each type of connection. For example, the classic interface
  53. name for a wired connection is eth0. A wireless connection
  54. will usually have the name wifi0 or wlan0.
  55. </para-->
  56. <para>
  57. 对于多数系统,每种连接类型只有一个网络接口。
  58. 例如,有线连接的经典接口名是 eth0,而无线连接的接口名一般是
  59. wifi0 或 wlan0。
  60. </para>
  61. <!--para>
  62. If you prefer to use the classic or customized network interface names,
  63. there are three alternative ways to do that:</para-->
  64. <para>
  65. 如果您偏爱经典或自定义网络接口名,可以使用三种不同方式:
  66. </para>
  67. <itemizedlist>
  68. <listitem>
  69. <para>
  70. 覆盖 udev 提供默认策略的 .link 文件:
  71. <screen role="nodump"><userinput>ln -s /dev/null /etc/systemd/network/99-default.link</userinput></screen>
  72. </para>
  73. </listitem>
  74. <listitem>
  75. <!--para>
  76. Create a manual naming scheme, for example by naming the
  77. interfaces something like "internet0", "dmz0", or "lan0".
  78. For that, create .link
  79. files in /etc/systemd/network/, that choose an explicit name or a
  80. better naming scheme for one, some, or all of your interfaces.
  81. For example:
  82. </para-->
  83. <para>
  84. 手动创建命名架构,例如将网络接口命名为
  85. <quote>internet0</quote>、<quote>dmz0</quote> 或
  86. <quote>lan0</quote>。为此,在 /etc/systemd/network
  87. 中创建 .link 文件,为您的一个、
  88. 一些或全部网络接口直接选择名称,或选择更好的命名架构。
  89. 例如:
  90. </para>
  91. <screen role="nodump"><userinput>cat &gt; /etc/systemd/network/10-ether0.link &lt;&lt; "EOF"
  92. <literal>[Match]
  93. # 将 MAC 地址替换为适用于您的网络设备的值
  94. MACAddress=12:34:45:78:90:AB
  95. [Link]
  96. Name=ether0</literal>
  97. EOF</userinput></screen>
  98. <para>
  99. 参阅 man 页面 systemd.link(5) 获得更多信息。
  100. </para>
  101. </listitem>
  102. <listitem>
  103. <para>
  104. 在 /boot/grub/grub.cfg 的内核命令行中传递选项
  105. net.ifnames=0。
  106. </para>
  107. </listitem>
  108. </itemizedlist>
  109. </sect3>
  110. <sect3 id="systemd-networkd-static">
  111. <title>静态 IP 配置</title>
  112. <para>以下命令为静态 IP 设置创建一个基本的配置文件
  113. (使用 systemd-networkd 和 systemd-resolved)。</para>
  114. <!-- jhalfs relies on the values for Name, Address, etc. If you want to change
  115. them, please inform the jhalfs maintainer(s). -->
  116. <screen><userinput>cat &gt; /etc/systemd/network/10-eth-static.network &lt;&lt; "EOF"
  117. <literal>[Match]
  118. Name=<replaceable>&lt;网络设备名&gt;</replaceable>
  119. [Network]
  120. Address=192.168.0.2/24
  121. Gateway=192.168.0.1
  122. DNS=192.168.0.1
  123. Domains=<replaceable>&lt;您的域名&gt;</replaceable></literal>
  124. EOF</userinput></screen>
  125. <para>如果您有多个 DNS 服务器,可以在配置文件中创建多个 DNS 项。
  126. 如果您希望使用静态 <filename>/etc/resolv.conf</filename> 文件,
  127. 则不要在配置文件中包含 DNS 和 Domains 项。</para>
  128. </sect3>
  129. <sect3 id="systemd-networkd-dhcp">
  130. <title>DHCP 配置</title>
  131. <para>以下命令为 IPv4 DHCP 配置创建基本配置文件:</para>
  132. <screen role="nodump"><userinput>cat &gt; /etc/systemd/network/10-eth-dhcp.network &lt;&lt; "EOF"
  133. <literal>[Match]
  134. Name=&lt;网络设备名&gt;
  135. [Network]
  136. DHCP=ipv4
  137. [DHCP]
  138. UseDomains=true</literal>
  139. EOF</userinput></screen>
  140. </sect3>
  141. </sect2>
  142. <sect2 id="resolv.conf">
  143. <title>创建 /etc/resolv.conf 文件</title>
  144. <indexterm zone="resolv.conf">
  145. <primary sortas="e-/etc/resolv.conf">/etc/resolv.conf</primary>
  146. </indexterm>
  147. <!--para>If the system is going to be connected to the Internet, it will
  148. need some means of Domain Name Service (DNS) name resolution to
  149. resolve Internet domain names to IP addresses, and vice versa. This is
  150. best achieved by placing the IP address of the DNS server, available
  151. from the ISP or network administrator, into
  152. <filename>/etc/resolv.conf</filename>.</para-->
  153. <para>如果要将系统连接到 Internet ,它需要某种域名服务(DNS)
  154. 名称解析方式,以将 Internet 域名解析为 IP 地址,
  155. 或将 IP 地址解析为域名。最好的方法是将 ISP 或网络管理员提供的
  156. DNS 服务器 IP 地址写入 <filename>/etc/resolv.conf</filename>。</para>
  157. <sect3 id="resolv-conf-systemd-resolved">
  158. <title>systemd-resolved 配置</title>
  159. <!--note><para>If using another means to configure your network
  160. interfaces (ex: ppp, network-manager, etc.), or if using any type of
  161. local resolver (ex: bind, dnsmasq, etc.), or any other software that
  162. generates an <filename>/etc/resolv.conf</filename> (ex: resolvconf), the
  163. <command>systemd-resolved</command> service should not be
  164. used.</para></note-->
  165. <note><para>如果使用其他方式配置网络接口(例如 ppp 或 network-manager
  166. 等),或使用了某种本地解析器(如 bind 或 dnsmasq 等),
  167. 或其他任何生成 <filename>/etc/resolv.conf</filename>
  168. 的软件(如 resolvconf),则不应使用
  169. <command>systemd-resolved</command> 服务。</para></note>
  170. <para>在使用 <command>systemd-resolved</command> 进行 DNS
  171. 配置时,它创建文件
  172. <filename>/run/systemd/resolve/resolv.conf</filename>。在
  173. <filename>/etc</filename> 中创建符号链接以使用生成的文件:</para>
  174. <screen><userinput>ln -sfv /run/systemd/resolve/resolv.conf /etc/resolv.conf</userinput></screen>
  175. </sect3>
  176. <sect3 id="resolv-conf-static">
  177. <title>静态 resolv.conf 配置</title>
  178. <para>如果希望使用静态的 <filename>/etc/resolv.conf</filename>
  179. 执行以下命令创建它:</para>
  180. <screen role="nodump"><userinput>cat &gt; /etc/resolv.conf &lt;&lt; "EOF"
  181. <literal># Begin /etc/resolv.conf
  182. domain <replaceable>&lt;您的域名&gt;</replaceable>
  183. nameserver <replaceable>&lt;您的主要域名服务器 IP 地址&gt;</replaceable>
  184. nameserver <replaceable>&lt;您的次要域名服务器 IP 地址&gt;</replaceable>
  185. # End /etc/resolv.conf</literal>
  186. EOF</userinput></screen>
  187. <para>可以省略 <varname>domain</varname> 语句,
  188. 或使用一条 <varname>search</varname> 语句代替它。
  189. 阅读 resolv.conf 的 man 页面了解更多细节。</para>
  190. <para>将
  191. <replaceable>&lt;域名服务器的 IP 地址&gt;</replaceable>
  192. 替换为您的网络环境下最合适的 DNS 服务器 IP 地址。
  193. 这里往往会写入不止一个 DNS 服务器(需要提供后备功能的次要服务器)。
  194. 如果您只需要或只希望使用一个 DNS 服务器,可以删除文件中的第二个
  195. <emphasis>nameserver</emphasis> 行。也可以写入本地路由器的 IP 地址。
  196. </para>
  197. <note><para>Google 公用 DNS 服务器的 IPv4 地址是
  198. <parameter>8.8.8.8</parameter> 和 <parameter>8.8.4.4</parameter>,
  199. IPv6 地址是 <parameter>2001:4860:4860::8888</parameter> 和
  200. <parameter>2001:4860:4860::8844</parameter>。</para></note>
  201. </sect3>
  202. </sect2>
  203. <sect2 id="ch-scripts-hostname">
  204. <title>配置系统主机名</title>
  205. <indexterm zone="ch-scripts-hostname">
  206. <primary sortas="d-hostname">hostname</primary>
  207. <secondary>configuring</secondary>
  208. </indexterm>
  209. <para>在引导过程中,<filename>/etc/hostname</filename>
  210. 被用于设定系统主机名。</para>
  211. <para>执行以下命令,创建 <filename>/etc/hostname</filename>
  212. 文件,并输入一个主机名:</para>
  213. <screen><userinput>echo "<replaceable>&lt;lfs&gt;</replaceable>" &gt; /etc/hostname</userinput></screen>
  214. <para><replaceable>&lt;lfs&gt;</replaceable>
  215. 需要被替换为赋予该计算机的名称。
  216. 不要在这里输入全限定域名 (FQDN) ,它应该被写入
  217. <filename>/etc/hosts</filename> 文件。</para>
  218. </sect2>
  219. <sect2 id="ch-scripts-hosts">
  220. <title>自定义 /etc/hosts 文件</title>
  221. <indexterm zone="ch-scripts-hosts">
  222. <primary sortas="e-/etc/hosts">/etc/hosts</primary>
  223. </indexterm>
  224. <indexterm zone="ch-scripts-hosts">
  225. <primary sortas="d-localnet">localnet</primary>
  226. <secondary>/etc/hosts</secondary>
  227. </indexterm>
  228. <indexterm zone="ch-scripts-hosts">
  229. <primary sortas="d-network">network</primary>
  230. <secondary>/etc/hosts</secondary>
  231. </indexterm>
  232. <para>选择一个全限定域名 (FQDN),和可能的别名,以供
  233. <filename>/etc/hosts</filename> 文件使用。如果使用静态 IP 地址,
  234. 您还需要确定要使用的 IP 地址。
  235. hosts 文件条目的语法是:</para>
  236. <screen><literal>IP_地址 主机名.域名 别名</literal></screen>
  237. <para>除非该计算机可以从 Internet 访问 (即拥有一个注册域名,
  238. 并分配了一个有效的 IP 地址段 —— 多数用户没有分配有效 IP),
  239. 确认使用的 IP 地址属于私网 IP 范围。有效的范围是:</para>
  240. <screen><literal>私网地址范围 公共前缀长度
  241. 10.0.0.1 - 10.255.255.254 8
  242. 172.x.0.1 - 172.x.255.254 16
  243. 192.168.y.1 - 192.168.y.254 24</literal></screen>
  244. <para>x 可以是 16-31 之间的任何数字,y 可以是 0-255 之间的任何数字。
  245. </para>
  246. <para>有效的私网 IP 地址的一个例子是 192.168.1.1。
  247. 与之对应的 FQDN 可以是 lfs.example.org。</para>
  248. <para>即使没有网卡,也要提供一个有效的 FQDN,
  249. 某些程序需要它才能正常工作。</para>
  250. <para>如果使用 DHCP、DHCPv6 或 IPv6 自动配置,或者不准备配置网卡,
  251. 执行以下命令创建 <filename>/etc/hosts</filename> 文件:</para>
  252. <screen role="nodump"><userinput>cat &gt; /etc/hosts &lt;&lt; "EOF"
  253. <literal># Begin /etc/hosts
  254. 127.0.0.1 localhost
  255. 127.0.1.1 <replaceable>&lt;FQDN&gt;</replaceable> <replaceable>&lt;主机名&gt;</replaceable>
  256. ::1 localhost ip6-localhost ip6-loopback
  257. ff02::1 ip6-allnodes
  258. ff02::2 ip6-allrouters
  259. # End /etc/hosts</literal>
  260. EOF</userinput></screen>
  261. <para>::1 是 127.0.0.1 在 IPv6 中的对应,即 IPv6 回环接口。 </para>
  262. <para>如果使用静态地址,执行以下命令创建
  263. <filename>/etc/hosts</filename> 文件:</para>
  264. <screen><userinput>cat &gt; /etc/hosts &lt;&lt; "EOF"
  265. <literal># Begin /etc/hosts
  266. 127.0.0.1 localhost
  267. 127.0.1.1 <replaceable>&lt;FQDN&gt;</replaceable> <replaceable>&lt;主机名&gt;</replaceable>
  268. <replaceable>&lt;192.168.0.2&gt;</replaceable> <replaceable>&lt;FQDN&gt;</replaceable> <replaceable>&lt;主机名&gt;</replaceable> <replaceable>[别名 1] [别名 2] ...</replaceable>
  269. ::1 localhost ip6-localhost ip6-loopback
  270. ff02::1 ip6-allnodes
  271. ff02::2 ip6-allrouters
  272. # End /etc/hosts</literal>
  273. EOF</userinput></screen>
  274. <para>其中 <replaceable>&lt;192.168.0.2&gt;</replaceable>、
  275. <replaceable>&lt;FQDN&gt;</replaceable> 和
  276. <replaceable>&lt;HOSTNAME&gt;</replaceable>
  277. 值需要为特定使用环境和需求进行修改
  278. (如果系统或网络管理员分配了 IP 地址,且本机将被连接到现有的网络中)。
  279. 可以跳过别名(alias),它们不是必要的。</para>
  280. </sect2>
  281. </sect1>