开发者社区> 行者武松> 正文

《Linux From Scratch》第三部分:构建LFS系统 第七章:基本系统配置- 7.2. 通用网络配置

简介:
+关注继续查看

 本节仅在需要配置网卡时参考。

7.2.1. 网络接口配置文件

从版本 209 开始,systemd 提供了一个名为 systemd-networkd 命令用于处理基本的网络配置。

systemd-networkd 的配置文件可能在 /usr/lib/systemd/network/etc/systemd/network 中,其中 /etc/systemd/network 中的配置文件优先级更高。

有三种配置文的类型:.link.netdev.network 。可以通过查阅 man 手册的 systemd-link(5)systemd-netdev(5)systemd-network(5) 可以获得更多关于这些配置文件的详细介绍。

[Note]

注意

udev 可能根据你电脑的物理设备特性将网卡接口设置为不同的名称,比如 enp2s1。如果你不能确定你的网卡名称,可以在系统启动后执行 ip link 命令查看。

译者注:通过执行 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: enp3s0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP mode DEFAULT
group default qlen 1000
link/ether fc:aa:14:2d:db:a1 brd ff:ff:ff:ff:ff:ff
3: wlp0s20u9: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP mode DORMANT group
default qlen 1000
link/ether 0c:82:68:52:85:57 brd ff:ff:ff:ff:ff:ff

其中斜体的部分就是物理网卡的名称。

以下内容摘录于 ArchLinux wiki

对于有多块网卡的电脑,固定设备名称很重要。许多配置问题都是由于网络接口名称变化引起的。

udev 负责给设备命名。Systemd v197 引入了可预测的网络接口名称自动给网络设备分配静态名称,网络接口现在是以前缀 en(以太网)、wl(WLAN)、或者 ww(WWAN)附上一个自动生成的标识符,产生了一个类似于 enp2s1 的条目。

7.2.1.1. 静态 IP 配置

通过以下的命令创建静态 IP 的基本配置文件:

cat > /etc/systemd/network/10-static-eth0.network << "EOF"
[Match]
Name=eth0

[Network]
Address=192.168.0.2/24
Gateway=192.168.0.1
DNS=192.168.0.1
EOF

在配置文件中,可以指定多个 DNS 条目。

7.2.1.2. DHCP 配置

通过以下的命令创建 DHCP 的基本配置文件:

cat > /etc/systemd/network/10-dhcp-eth0.network << "EOF"
[Match]
Name=eth0

[Network]
DHCP=yes
EOF

需要注意的是,当前 systemd-networkd 仅能够处理 DHCPv4。DHCPv6 的支持正在快马加鞭的筹划中。

7.2.2. 创建 /etc/resolv.conf 文件

如果你的系统需要连接到互联网,它需要利用 DNS 服务将互联网域名解析为实际的 IP 地址,反之亦然。最好的方法是将从 ISP 或者是网络管理员那里取得的 DNS 服务器地址填入 /etc/resolv.conf

如果需要静态的 /etc/resolv.conf 文件,请使用以下命令:

cat > /etc/resolv.conf << "EOF"
# Begin /etc/resolv.conf

domain <Your Domain Name>
nameserver <IP address of your primary nameserver>
nameserver <IP address of your secondary nameserver>

# End /etc/resolv.conf
EOF

domain 声明可以忽略或者以 search 声明替换。参考 man 手册的 resolv.conf 部分获得更多信息。

其中,<IP address of the nameserver> 替换为最合适的 DNS 的 IP 地址。通常会有多个条目(需要备选服务器具有相关兼容性)。如果你只需要一台 DNS 服务器,请不要输入第二行 nameserver 的内容。该 IP 地址也可以是本地网络中的一台路由。

[Note]

注意

Google 公开 IPv4 DNS 解析服务器地址为 8.8.8.8 和 8.8.4.4。
(译者注:国内也有一些 IT 公司提供公开可用的 DNS 解析服务:
114 DNS:114.114.114.114 和 114.114.115.115
阿里 DNS:223.5.5.5 和 223.6.6.6
百度 DNS:180.76.76.76
OpenDNS:208.67.220.220)

当使用 systemd-networkd 配置网络,另一个守护进程 systemd-resolved 将会创建 /etc/resolv.conf 文件。然后在早先版本中此文件的路径并不标准,因此你需要使用以下的命令创建到标准位置的链接:

ln -sfv /run/systemd/resolve/resolv.conf /etc/resolv.conf

对于在 .network 文件中指定了 DNS 或者使用内置 DHCP 客户端获得 DNS 这两种情况,必须要做如上操作。

7.2.3. 配置系统主机名称

在系统启动过程中,/etc/hostname 文件用于创建系统的主机名称。

通过以下命令创建 /etc/hostname 文件:

echo "<lfs>" > /etc/hostname

<lfs> 替换为你想要设置的名称。请不要输入完整域名(Fully Qualified Domain Name,FQDN),它应该在 /etc/hosts 文件中。

7.2.4. 自定义 /etc/hosts 文件

将确定IP地址、完整域名(Fully-Qualified Domain Name,FQDN)和可能的别名填入/etc/hosts 文件中。语法是:

IP_address myhost.example.org aliases

除非当前电脑对互联网可见(即已经注册有域名且分配有效的 IP 段——放心吧,大多数用户都没有),否则请确保 IP 地址位于专有网络 IP 段。有效的范围是:

私人网络地址范围     		正常前缀
10.0.0.1 - 10.255.255.254           8
172.x.0.1 - 172.x.255.254           16
192.168.y.1 - 192.168.y.254         24

x 为 16-31 之间的任意值。Y 为 0-255 之间的任意值。

有效的专有 IP 地址形如 192.168.1.1,有效的完整域名形如 lfs.example.org。

就算没有网卡,也应该提供有效的完整域名,否则某些软件可能无法正常运行。

通过以下命令创建 /etc/hosts 文件:

cat > /etc/hosts << "EOF"
# Begin /etc/hosts (network card version)

127.0.0.1 localhost
::1       localhost
<192.168.0.2> <HOSTNAME.example.org> [alias1] [alias2] ...

# End /etc/hosts (network card version)
EOF

<192.168.0.2> <HOSTNAME.example.org> 应该更改为需要设置的值(如果此 IP 地址是由网络/系统管理员分配的且电脑可以连接到存在的网络)。别名可以省略。

如果暂时不打算进行以上的配置,那直接运行下面的命令创建最通用的 /etc/hosts 文件:

cat > /etc/hosts << "EOF"
# Begin /etc/hosts (no network card version)

127.0.0.1 <HOSTNAME.example.org> <HOSTNAME> localhost
::1       localhost

# End /etc/hosts (no network card version)
EOF

::1 为 IPv6 对应的 127.0.0.1,且为 IPv6 的回环接口。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
consul技术分享
上一章《注册中心Eureka》我们介绍了注册中心Eureka,相必大家都对注册中心都有了一定的认识了,在Eureka停止维护之后,Consul就成了其替换方案之一,让我们一起来走进Consul的世界吧!
4 0
云服务器部署后台过程记录
现做毕业设计,使用前后端分离的设计模式,后端完成后为方便后续调用以及维护,将后端打包后部署到ECS云服务器上,在此介绍部署流程及一些问题。
5 0
飞天加速计划·高校学生在家实践--aimafan
为了可以更好地学习关于服务器的相关知识,我申请了阿里云的ECS服务器,在试用了两周之后,收获颇丰。
4 0
HTTPS这样回答还拿不到offer?
每次访问一个网站的时候大家对http与htps都不陌生吧?随着网络技术的发展,这些词充斥着我们的耳朵。
4 0
ArrayList这样回答还拿不到offer?
这是我实习的第二个月。今天讲述的是ArrayList。大家肯定对这个很熟悉,比如日常开发过程中,不管是前后端分离开发还是不分离开发,都会利用接口调用SQL语句查询数据。查询到的结果是存入ArrayList里的。问题来了!
3 0
VIM 简单使用1
Vim是从 vi 发展出来的一个文本编辑器。代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。 简单的来说, vi 是老式的字处理器,不过功能已经很齐全了,但是还是有可以进步的地方。 vim 则可以说是程序开发者的一项很好用的工具。 连 vim 的官方网站 (http://www.vim.org) 自己也说 vim 是一个程序开发工具而不是文字处理软件。
5 0
JetBrains Mono 字体安装
JetBrains 推出编程字体Mono:更适合程序开发人员 JetBrains 表示:在当今的大部分时间里,我们作为开发人员都在看代码。我们一直在寻找最佳字体,以使我们更容易在屏幕上查看文本。但是,许多流行字体中的逻辑并不总是考虑到通读代码和阅读书本之间的区别。我们的眼睛以非常不同的方式沿代码移动,通常必须垂直移动和水平移动,这与阅读书籍不同,因为它们总是沿同一方向沿文本滑动。
4 0
Go 语言 第一课
Go 是一个开源的编程语言,它能让构造简单、可靠且高效的软件变得容易。 Go是从2007年末由Robert Griesemer, Rob Pike, Ken Thompson主持开发,后来还加入了Ian Lance Taylor, Russ Cox等人,并最终于2009年11月开源,在2012年早些时候发布了Go 1稳定版本。现在Go的开发已经是完全开放的,并且拥有一个活跃的社区。
4 0
docker 简介和安装
Docker 的应用场景 • Web 应用的自动化打包和发布。 • 自动化测试和持续集成、发布。 • 在服务型环境中部署和调整数据库或其他的后台应用。 • 从头编译或者扩展现有的 OpenShift 或 Cloud Foundry 平台来搭建自己的 PaaS 环
5 0
云起实验室第一期学习
云起实验室第一期学习
6 0
+关注
行者武松
杀人者,打虎武松也。
17142
文章
2569
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载