逐步实验完善ing…
在Ubuntu系的Linux系统里,与网络相关的主要设置文件如下:
/etc/host.conf
配置域名服务客户端的控制文件
/etc/hosts
配置主机名和IP地址的映射
/etc/resolv.conf
域名服务客户端的配置文件,指定域名服务器的IP地址
/etc/network/interfaces
用于设置网络配置信息(IP地址,子网掩码,网关IP等)
/etc/udev/rules.d/70-persistent-net.rules
记录主机中所有网卡的MAC地址
/etc/xinetd.conf
定义了由进程守护程序xinetd所守护的网络服务
/etc/networks
实现域名与网络地址的映射
/etc/protocols
设定主机使用的协议及各个协议的协议号(协议ID)
/etc/services
设定主机上各个网络服务进程所使用的端口号
/etc/host.conf
文件的默认内容如下:
# The"order" line is only used by old versions of the C library.
order hosts,bind # 指定主机名的解析顺序,即本地解析,DNS域名解析
multi on # 允许主机拥有多个IP地址
这个文件一般不需要我们修改,默认的解析顺序是本地解析,DNS服务器解析。也就是说在本系统里对于一个主机名首先进行本地解析,如果本地解析没有,然后进行DNS服务器解析。
/etc/hosts
文件的默认内容如下(不同主机,IP映射的主机名不同):
127.0.0.1 butbueatiful localhost.localdomain localhost
::1 localhost6.localdomain6 localhost6
可见,默认的情况是本机ip和本机一些主机名的对应关系,第一行是ipv4信息,第二行是ipv6信息,如果用不上ipv6本机解析,一般把该行注释掉。
第一行的解析效果是,butbueatiful localhost.localdomain localhost三者都会被解析成127.0.0.1,我们可以用ping试试。
[root@butbueatiful ~]# ping -c 3 butbueatiful
PING butbueatiful (127.0.0.1) 56(84) bytes ofdata.
64 bytes from butbueatiful (127.0.0.1):icmp_seq=1 ttl=64 time=0.061 ms
64 bytes from butbueatiful (127.0.0.1):icmp_seq=2 ttl=64 time=0.052 ms
64 bytes from butbueatiful (127.0.0.1):icmp_seq=3 ttl=64 time=0.051 ms
--- butbueatiful ping statistics ---
3 packets transmitted, 3 received, 0% packetloss, time 1999ms
rtt min/avg/max/mdev = 0.051/0.054/0.061/0.009ms
[root@butbueatiful ~]# ping -c 3localhost.localdomain
PING butbueatiful (127.0.0.1) 56(84) bytes ofdata.
64 bytes from butbueatiful (127.0.0.1):icmp_seq=1 ttl=64 time=0.055 ms
64 bytes from butbueatiful (127.0.0.1):icmp_seq=2 ttl=64 time=0.035 ms
64 bytes from butbueatiful (127.0.0.1):icmp_seq=3 ttl=64 time=0.050 ms
--- butbueatiful ping statistics ---
3 packets transmitted, 3 received, 0% packet loss,time 1999ms
rtt min/avg/max/mdev = 0.035/0.046/0.055/0.011 ms
看到上面的结果,你可能会问为什么ping localhost.localdomain的时候,下面显示的是却是butbueatiful,这是因为第一个主机名butbueatiful后面的那些主机名其实都是butbueatiful的主机别名。
如果我们要追加新的本地解析,比如我们希望在我们的机器里把yyyy.com和www.yyyy.com都解析成192.168.0.100,那么就追加如下一句即可:
192.168.0.100 yyyy.com www.yyyy.com
同样,在这里,www.yyyy.com是yyyy.com的主机别名。
如果你仔细一想,会发现,其实这个文件是很危险的,如果有人恶意修改了你这个文件,比如把淘宝的网站域名解析到了他的钓鱼网站,那你就要中招了。
该文件用来指定DNS域名解析服务器的IP信息,其配置参数一般有以下四个:
nameserver #指定DNS服务器的IP地址
domain #定义本地域名信息
search #定义域名的搜索列表
sortlist #对gethostbyname返回的地址进行排序
但是最常用的配置参数是nameserver,其他的可以不设置,这个参数指定了DNS服务器的IP地址,如果设置不正确,就无法进行正常的域名解析。
一般来说,推荐设置2个DNS服务器,比如我们用google的免费DNS服务器,那么该文件的设置内容如下:
nameserver 8.8.8.8
nameserver 8.8.4.4
同样,这个文件也是危险的,如果被人恶意改成了他自己的DNS服务器,他就可以为所欲为的控制你通过域名访问的每个目的地了,这就是常说的DNS劫持。
interfaces网络接口配置文件,是Ubuntu网络配置中最为重要的一个文件。本文件用来设定主机的IP类型,IP地址,子网掩码,网关IP,广播地址,MAC物理地址等信息,详细的配置方法参见本文第二章节,以下以静态IP配置给出该文件的内容示例。
auto lo
iface lo inetloopback
auto eth0 # 指明当前配置的是主机上的eth0网卡
iface eth0 inetstatic # 将eth0网卡配置为静态IP类型
address10.8.210.145 # 手动设定eth0网卡的IP地址为10.8.210.145
netmask255.255.255.0 # 手动设定子网掩码
gateway10.8.210.7 # 手动设定网关IP
#pre-up ifconfigeth0 hw ether 11:22:33:44:55:66 # 手动设定MAC地址
【说明】一般网卡的MAC地址是由厂家设定好的,系统启动的时候可以侦测到MAC地址,如非特殊需求,一般情况下不必人为修改。故而此处将该配置信息注释掉,只做示例。
该文件属于主机的一个记录文件,其主要作用就是记录主机识别到的网卡信息。每当识别到一个新的网络接口配置信息,就会自动追加到该文件,用户也可以自己添加网络接口信息。主机识别网卡信息主要依据就是通过MAC地址。
该文件就是简单的用include命令指定了xinetd守护进程可以读取的配置文件,所有xinetd可读取的配置文件其实都放在/etc/xinted.d目录下面。xinetd守护进程通过读取不同的服务进程的配置文件,启动并配置相应的服务进程。
/etc/networks
# 实现域名与网络地址的映射
/etc/protocols
# 设定主机使用的协议及各个协议的协议号(协议ID)
/etc/services
# 设定主机上各个网络服务进程所使用的端口号
上述三个配置文件的作用如注释所说,一般保持默认,不必修改。
Ubuntu在Desktop版本中,提供了两种方法来进行网络参数配置。即图形界面和文本命令行配置。文本命令行方式是通过修改/etc/network/interfaces
来进行配置的。而图形界面配置是通过network-manager
进行配置,通过启动Ubuntu桌面的SystemàPreferencesàNetwork Connections即可进行图形化配置。network-manager
的配置和直观,按照提示一步一步操作即可,读者可以自行查阅相关的配置方法。
但如果修改了interfaces
配置文件,又配置了network-manager
(以下简称nm
),就会出现一些莫名其妙的问题:
interfaces
和 nm
中的网络设置不一样,系统实际的IP是哪个?
有时候莫名其妙的,界面右上角的网络连接图标就丢失了。
明明在nm
中配置了正确的网络设置,为什么就上不了网呢?
其实,只要弄清楚interfaces
和 nm
之间的关系,这些问题就不难解释了。
首先,当系统内没有第三方网络管理工具(比如nm
)时,系统默认使用nterfaces
文件内的参数进行网络配置。
接着,当系统内安装了nm
之后,nm
默认接管了系统的网络配置,使用nm
自己的网络配置参数来进行配置。
但是,如果用户在安装nm
之后(Desktop版本默认安装了nm),自己手动修改了interfaces
文件,那nm
就自动停止对系统网络的管理,系统改使用interfaces
文件内的参数进行网络配置。
此时,再去修改nm
内的参数,不影响系统实际的网络配置。若要让nm 内的配置生效,必须重新启用nm
接管系统的网络配置。
现在知道了两者之间的工作关系,再看上面的三个问题:
要看nm
是否接管,如果没有接管,系统实际的IP设置以interfaces 中的为准。反之,以nm
中的为准。
当nm
停止接管的时候,网络连接图标就丢失了。
同样是接管的问题。
如果用户希望在Desktop版本中,直接使用interfaces 进行网络配置,那么可以通过以下指令来关闭network-manager
:
/etc/init.d/network-managerstop # 手动关闭network-manager
之后通过查看/etc/NetworkManager/nm-system-settings.conf
文件来确定nm
是否停止网络配置工作。即只需要确保/etc/NetworkManager/nm-system-settings.conf
内的managed=false
。
之后就可以通过文件命令行方式进行网络参数配置。
vi/etc/network/interfaces # 手动修改interfaces配置文件
/etc/init.d/networkingrestart # 配置完成后,重启网络服务
如果希望能继续使用nm
来进行网络配置,则需要进行如下操作:
sudo service network-manager stop # 停止nm服务
sudo rm /var/lib/NetworkManager/NetworkManager.state# 移除nm 的状态文件
sudo gedit /etc/NetworkManager/nm-system-settings.conf# 打开nm 的配置文件
修改文件里面这一行:managed=false
,将false
修改成true
,然后重启nm
程序,指令如下:
sudo servicenetwork-manager start # 由nm程序重新接管网络配置工作
【注意】如果手工改过/etc/network/interfaces
,`nm会自己把这行改成:managed=false(这里应该默认就是false)
首先通过ifconfig查看网卡信息,显示网卡enp0s31f6和网卡lo
一般通过修改/etc/network/interfaces配置文件设置网络接口参数,示例如下:
#配置环回网络,系统默认就好,一般不必修改。
auto lo
iface lo inetloopback
#配置静态IP配置
#auto enp0s31f6 # 配置enp0s31f6网卡
#iface enp0s31f6 inetstatic # 将enp0s31f6网卡设置为静态IP
#address10.8.210.145 # 配置enp0s31f6网卡的IP地址
#netmask255.255.255.0 # 配置enp0s31f6网卡的子网掩码
#gateway10.8.210.7 # 配置enp0s31f6网卡的网关地址
#auto eth0:1 # 创建基于eth0网卡的虚拟网卡,即让一个网卡拥有过个IP
#iface eth0:1inet static # 将虚拟网卡eth0:1设置为静态IP
#address192.168.1.10 # 配置虚拟网卡eth0:1网卡的IP地址
#netmask255.255.255.0 # 配置虚拟网卡eth0:1网卡的子网掩码
#gateway192.168.1.1 # 配置虚拟网卡eth0:1网卡的网关地址
#动态IP配置
auto eth0
iface eth0 inetdhcp # 将eth0网卡设置为动态IP
系统按主机中网卡的个数进行编号,例如主机存在三张网卡,则分别为eth0
,eth1
和eth2
。每张网卡均可配置多个虚拟网络IP。上述配置中,屏蔽了静态IP配置,启用的是动态IP配置。
之后需要在/etc/resolv.conf
配置文件中指定DNS域名服务器的IP地址信息,参见第一小节说明。
配置完成后,执行如下指令,使配置生效:
/etc/init.d/networkingforce-reload # 重新载入配置文件
/etc/init.d/networking restart # 重启网络服务
或者
ifconfig enp0s31f6 down #关闭网卡
ifconfig enp0s31f6 up #开启网卡
目前我所掌握的 Ubuntu 下通过配置文件设置DNS的方式有两种:interfaces 和 resolvconf.
(1)interfaces方式
修改/etc/network/interfaces
配置DNS需要在该文件中加入
dns-nameserver xx.xx.xx.xx
dns-nameserver xxx.xxx.xx.xx
dns-nameservers xxx.xxx.xxx.xxx xxx.xxx.xx.xxx
备注: 这种方式修改DNS后需要重启电脑方可生效(我没有找到其它使其生效的方式,重启网络并不能更新cat /etc/resolv.conf。
(2)resolvconf方式
resolvconf方式修改DNS则是通过修改/etc/resolvconf/resolv.conf.d/head
文件实现,当需要添加DNS记录时,在文件中加入下面内容:
nameserver xxx.xxx.xx.xxx
nameserver xx.xx.xx.xx
修改成功后,运行sudo resolvconf -u更新/etc/resolv.conf文件即可。这种方式不需要重启电脑。
备注: 看到网上说可以修改/etc/resolvconf/resolv.conf.d/base文件同样能配置DNS,但经我测试,不能正确配置,不知道是什么原因。
Ubuntu是在虚拟机里安装的,刚开始正常,网卡设备名为eth0。后来添加一块网卡(虚拟的),然后eth0就消失了,只有eth1和eth2了。原来问题出在文件/etc/udev/rules.d/70-persistent-net.rules中。由于以前可以更改过MAC地址,所以70-persistent-net.rules中仍然保留了老网卡的内容,新网卡则被识别为eth1,eth2。
将表示老网卡的行注释掉,然后将表示新网卡的行中eth1改成eth0,eth2改为eth1重启即可
ifconfig # 查看网络信息
ifconfig ethx 10.8.210.150 # 临时设置ethx网卡的IP地址为10.8.210.150 (重启后失效)
例如:
ifconfig eth0 10.8.210.150
ifconfig ethx:y 192.168.1.125 # 临时创建ethx网卡的虚拟网卡(重启后失效)
例如:
ifconfig eth0:0 192.168.1.125 # 创建eth0的第一张虚拟网卡,并设置IP地址
ifconfig eth0:1 192.168.3.250 # 创建eth0的第二张虚拟网卡,并设置IP地址
ifconfig ethx:y down # 临时删除ethx网卡的虚拟网卡(重启后失效)
虚拟网卡的永久配置方式需要修改配置文件,参见本文第二章节第二点。
ifup ethx # 启用网卡ethx (x=0,1,2,3……),需要root权限
ifdown ethx # 禁用网卡ethx,需要root权限
ifconfig ethx up # 启用网卡ethx(x=0,1,2,3……),需要root权限
ifconfig ethx down # 禁用网卡ethx,需要root权限
两种启动/禁止网卡设备方法的区别参见一下文章:
http://blog.csdn.net/gdutlyp/article/details/50498202
/etc/init.d/networking start # 启动网络服务
/etc/init.d/networking stop # 关闭网络服务
/etc/init.d/networking restart # 重启网络服务
/etc/init.d/networking force-reload # 强制重载网络配置
reference:
https://blog.csdn.net/GDUTLYP/article/details/73087476
https://blog.csdn.net/japinli/article/details/54897264