linux网络配置相关文件

简介: 网络接口(interface)是网络硬件设备在操作系统中的表示方法,比如网卡在Linux操作系统中用ethX,是由0开始的正整数,比如eth0、eth1...... ethX。而普通猫和ADSL的接口是 pppX,比如ppp0等; 机器中所有可用网卡及名字: 参考:linux网络配置相关命令、虚拟网...

网络接口(interface)是网络硬件设备在操作系统中的表示方法,比如网卡在Linux操作系统中用ethX,是由0开始的正整数,比如eth0、eth1...... ethX。而普通猫和ADSL的接口是 pppX,比如ppp0等; 

机器中所有可用网卡及名字: 
参考:linux网络配置相关命令、虚拟网络接口eth0:0 

网关GateWay配置地址: 
/etc/sysconfig/network  GATEWAY=192.168.1.250 
/etc/sysconfig/network-scripts/ifcfg-eth0 GATEWAY=192.168.1.250 

DNS配置地址: 
/etc/resolv.conf 
一般DHCP方式获得Ip地址时,网关、路由、Ip地址等信息都不需要手动设置! 

网络配置相关文件: 

  • /etc/sysconfig/network-scripts/ifcfg-ethX : Configuration file for network interfaces 网络接口(网卡)的配置文件(配置IP,掩码,广播地址,MAC地址,网关地址,DHCP等) 如果增加了一块网卡,那么可以手动把ifcfg-eth0复制一份并命名为ifcfg-eth1,修改配置后,重启网络即可
  • /etc/sysconfig/network 网络基础设置文件(配置主机名、网络是否可用等)
  • /etc/resolv.conf        配置DNS域名解析服务器
  • /etc/networks 网络定义文件:显示已知的网络名信息(一般默认不需要修改)
  • /etc/hosts              配置IP地址和主机名的映射(一般默认不需要修改)
  • /etc/services           网络服务列表及服务和端口号之间的映射(一般默认不需要修改)
  • /etc/host.conf          配置域名查找顺序1(一般默认不需要修改)
  • /etc/nsswitch.conf      配置域名查找顺序2(一般默认不需要修改)


这些文件都可以在系统运行时进行修改,不用启动或者停止任何守护程序,更改会立刻生效(除了/etc/sysconfig/network 和 /etc/sysconfig/network-scripts/ifcfg-ethX)。另外,这些文件都支持由"#"开头的注释,每一个文件都有在Linux帮助手册页中的第5部分中有一项,可以用man命令来获取它们。 

/etc/sysconfig/network-scripts/ifcfg-ethX : 网络接口(网卡)的配置文件(配置IP,掩码,广播地址,MAC地址,网关地址,DHCP等),修改后需要重启网络。 
配置DHCP: 
DEVICE=eth0 
BOOTPROTO=dhcp 
ONBOOT=yes(dhcp的配置方法就是这么简单) 

配置静态地址: 
DEVICE=eth0 
BOOTPROTO=static(或者是none) 
IPADDR=192.168.0.1 
NETMASK=255.255.255.0 
GATEWAY=192.168.0.254 
ONBOOT=yes 

参数解释: 
完整的参数说明参考:Linux Certif - Man ifcfg(5) 

  • DEVICE=eth0#网卡设备名称 - 必须字段
  • BOOTPROTO=static#系统获取IP的协议类型 dhcp bootp none - 必须字段
  • ONBOOT=yes#启动时是否激活 yes | no - 必须字段
  • IPADDR=192.168.1.90#网络IP地址 - static静态IP时必须
  • NETMASK=255.255.255.0#网络子网掩码地址 - static静态IP时必须
  • TYPE=Ethernet#网卡类型为以太网
  • HWADDR=00:0C:29:FE:1A:09#网卡MAC地址
  • BROADCAST=192.168.1.255#广播地址 - 根据Ip地址和子网掩码地址可以计算得到
  • GATEWAY=192.168.1.1#网关地址
  • USERCTL=answer, 非root用户是否可以控制该设备: yes 是 | no 否


/etc/sysconfig/network 网络基础设置文件(配置主机名、网络是否可用等) 
该文件用来指定服务器上的网络配置信息,包含了控制网络是否可用、主机名等信息。下面是一个例子文件: 

Html代码   收藏代码
  1. NETWORKING=yes  
  2. HOSTNAME=machine1  
  3. GATEWAY=210.34.6.2  
  4. FORWARD_IPV4=yes  
  5. GATEWAYDEV=  

 

  • NETWORK=yes/no 表示网络是否被配置;
  • HOSTNAME=hostname hostname 表示服务器的主机名;
  • GATEWAY=gw-ip gw-ip 表示网络网关的IP地址;
  • FORWARD_IPV4=yes/no 是否开启IP转发功能;
  • GAREWAYDEV=gw-dev gw-dw 表示网关的设备名,如:eth0等;


/etc/resolv.conf 配置DNS域名解析服务器 
文件/etc/resolv.conf配置DNS域名解析服务器,它包含了主机的域名搜索顺序和DNS服务器的地址,每一行应包含一个关键字和一个或多个的由空格隔开的参数。下面是一个例子文件: 

Html代码   收藏代码
  1. search mydom.edu.cn  
  2. nameserver 210.34.0.14  
  3. nameserver 210.34.0.2  


合法的参数及其意义如下: 

  • nameserver 表明DNS服务器的IP地址。可以有很多行的nameserver,每一个带一个I P地址。在查询时就按nameserver在本文件中的顺序进行,且只有当第一个nameserver没有反应时才查询下面的nameserver.
  • domain 声明主机的域名。很多程序用到它,如邮件系统;当为没有域名的主机进行DNS查询时,也要用到。如果没有域名,主机名将被使用,删除所有在第一个点( . )前面的内容。
  • search 它的多个参数指明域名查询顺序。当要查询没有域名的主机,主机将在由search声明的域中分别查找。domain和search不能共存;如果同时存在,后面出现的将会被使用。
  • sortlist 允许将得到域名结果进行特定的排序。它的参数为网络/掩码对,允许任意的排列顺序。Red Hat中没有提供缺省的/etc/resolv.conf文件,它的内容是根据在安装时给出的选项动态创建的。


/etc/networks 网络定义文件:显示已知的网络名信息 
该文件是一个用来描述已知DARPA网络和名称的纯文本文件。每一行代表一个network 

/etc/hosts 配置IP地址和主机名的映射 
/etc/hosts中包含了IP地址和主机名之间的映射,格式:IP地址 标准主机名 [ 多个可选别名]。下面是一个例子文件: 

Html代码   收藏代码
  1. 127.0.0.1 localhost localhost.localdomain machine1   
  2. 192.168.1.100 machine7  
  3. 192.168.1.101 otherpc otheralias  



/etc/services:网络服务列表及服务和端口号之间的映射 
/etc/services中包含了所有的网络服务名和端口号之间的映射,不少的系统程序要使用这个文件。linux系统端口分类:通用端口:0-1023 可注册端口:1024-49151 动态或者私有端口:49152-65535。下面是RedHat 安装时缺省的/etc/services中的前几行: 

Html代码   收藏代码
  1. tcpmux 1/tcp # TCP port service multiplexer  
  2. echo 7/tcp  
  3. echo 7/udp  
  4. discard 9/tcp sink null  
  5. discard 9/udp sink null  
  6. systat 11/tcp users  


最左边一列是网络服务名,中间一列是端口号,”/“ 后面是端口类型,可以是TCP也可以是UDP。任何后面的列都是前面服务的别名。在这个文件中也存在着别名,它们出现在端口号后面,在上述例子中sink和null 都是discard服务的别名。 

/etc/host.conf 配置域名查找顺序1 
有两个文件声明系统到哪里寻找名字信息来配置UNIX名字解析器的库。文件/etc/host.conf由版本5的libc库所使用,而/etc/nsswitch.conf由版本6使用(glibc )。问题在于一些程序使用其中一个,而一些使用另一个,所以将两个文件都配置正确是必要的。 
/etc/host.conf文件指定如何解析主机名,linux通过解析器库来获得主机名对应的IP地址。下面是RedHat安装后缺省的"/etc/host.conf"内容: 

Html代码   收藏代码
  1. order hosts,bind  
  2. multi on  

 

  • "order " 指定主机名查询顺序,其参数为用逗号隔开的查找方法,支持的查找方法为bind、hosts和nis,分别代表DNS、/etc/hosts和NIS,这里规定先查询"/etc/hosts"文件然后再使用DNS来解析域名。
  • "trim" 表明当通过DNS进行地址到主机名的转换时,域名将从主机名中被裁剪掉,trim可以被多个域包含多次,对/etc/hosts和NIS查询方法不起作用,注意在/etc/hosts和NIS表中主机名是被适当地(有或没有全域名)列出的。
  • "multi" 指定是否"/etc/hosts"文件中指定的主机可以有多个地址,值为on表示允许,拥有多个IP地址的主机一般称为具有多个网络界面。
  • "nospoof " 指是否允许对该服务器进行IP地址欺骗,值为on表示不允许,IP欺骗是一种攻击系统安全的手段,通过把IP地址伪装成别的计算机,来取得其它计算机的信任。
  • "alert" 当nospoof指令为on时,alert控制欺骗的企图是否用syslog工具进行记录,值为on表示使用,缺省值为off。
  • "rccorder" 如果被设置为on,所有的查询将被重新排序,所以在同一子网中的主机将首选被返回,缺省值为off。



/etc/nsswitch.conf 配置域名查找顺序2 
/etc/nsswitch.conf文件是由Sun公司开发并用于管理系统中多个配置文件查找的顺序,它比/etc/host.conf文件提供了更多的功能。/etc/nsswitch.conf中的每一行或者是注释(以#号开头)或者是一个关键字后跟冒号和一系列要试用的有顺序的方法。每一个关键字是在/etc/目录可以被/etc/nsswitch.conf控制的/etc文件的名字。下面是可以被包含的关键字: 

  • aliases 邮件别名;
  • passwd 系统用户;
  • group 用户组;
  • shadow 隐蔽口令;
  • hosts 主机名和I P地址;
  • networks 网络名和号;
  • protocols 网络协议;
  • services 端口号和服务名称;
  • ethers 以太网号;
  • rpc 远程进程调用的名称和号
  • netgroup 网内组


下面也是可以包含的关键字: 

    • files 除了netgroup,对其他关键字都有效。在相应的/etc文件中寻找记录
    • db 除了netgroup,对其他关键字都有效。在相应的/var/db数据库中寻找记录。对长文件很有效,如passwd文件已经 超过500项。要从标准/etc文件中产生这些文件,应改变目录到/var/db并运行run命令
    • compat 兼容性模式,对passwd、group和shadow文件有效。在本模式中,将先在对应的/etc文件中查找。如果想进行NIS查找,需要第一个值(用 户名或组名)为加号( + ),后面跟对应数量的冒号( : ) ( /etc/passwd为6个, /etc/group为3个, /etc/shadow为8个)。如在/etc/passwd文件中,下面一行应被包含在文件尾: + : * : : : : :
    • dns 只对hosts有意义。像在/etc/resolvconf配置的,在DNS中进行查找
    • nis 对所有的关键字都有意义。如NIS是可以用的,在NIS服务器中查找
    • [ STATUS = action ] 控制名字服务的行为。STATUS是SUCCESS(操作被成功执行)、NOTFOUND (记录没找到)、UNAVAIL (所选择的服务不可用)和TRYAGAIN (服务暂时不可用,请重试)中的一个。action是return (终止查找并返回当前状态)或continue (继续这一行的其他项)中的一个。如hosts: dns nis [NOTFOUND=return] files将会首先在DNS中,然后在NIS中查找主机名。只有当前两项都不可用时才使用文件/etc/hosts
目录
相关文章
|
10天前
|
安全 Linux 虚拟化
网络名称空间在Linux虚拟化技术中的位置
网络名称空间(Network Namespaces)是Linux内核特性之一,提供了隔离网络环境的能力,使得每个网络名称空间都拥有独立的网络设备、IP地址、路由表、端口号范围以及iptables规则等。这一特性在Linux虚拟化技术中占据了核心位置🌟,它不仅为构建轻量级虚拟化解决方案(如容器📦)提供了基础支持,也在传统的虚拟机技术中发挥作用,实现资源隔离和网络虚拟化。
网络名称空间在Linux虚拟化技术中的位置
|
10天前
|
网络协议 安全 Linux
Linux网络名称空间之独立网络资源管理
Linux网络名称空间是一种强大的虚拟化技术🛠️,它允许用户创建隔离的网络环境🌐,每个环境拥有独立的网络资源和配置。这项技术对于云计算☁️、容器化应用📦和网络安全🔒等领域至关重要。本文将详细介绍在Linux网络名称空间中可以拥有的独立网络资源,并指出应用开发人员在使用时应注意的重点。
|
10天前
|
安全 网络协议 Linux
Linux网络名称空间概述
Linux网络名称空间是操作系统级别的一种虚拟化技术🔄,它允许创建隔离的网络环境🌐,使得每个环境拥有自己独立的网络资源,如IP地址📍、路由表🗺️、防火墙规则🔥等。这种技术是Linux内核功能的一部分,为不同的用户空间进程提供了一种创建和使用独立网络协议栈的方式。本文旨在全方面、多维度解释Linux网络名称空间的概念、必要性和作用。
Linux网络名称空间概述
|
18天前
|
Linux
Linux中centos桌面消失网络图标
Linux中centos桌面消失网络图标
13 0
|
18天前
|
Linux Shell
Linux手动清理Linux脚本日志定时清理日志和log文件执行表达式
Linux手动清理Linux脚本日志定时清理日志和log文件执行表达式
72 1
|
17天前
|
人工智能 安全 Linux
【Linux】Linux之间如何互传文件(详细讲解)
【Linux】Linux之间如何互传文件(详细讲解)
|
8天前
|
存储 算法 Linux
【实战项目】网络编程:在Linux环境下基于opencv和socket的人脸识别系统--C++实现
【实战项目】网络编程:在Linux环境下基于opencv和socket的人脸识别系统--C++实现
24 6
|
10天前
|
网络协议 Linux
在Linux中,管理和配置网络接口
在Linux中管理网络接口涉及多个命令,如`ifconfig`(在新版本中被`ip`取代)、`ip`(用于网络设备配置)、`nmcli`(NetworkManager的CLI工具)、`nmtui`(文本界面配置)、`route/ip route`(处理路由表)、`netstat/ss`(显示网络状态)和`hostnamectl/systemctl`(主机名和服务管理)。这些命令帮助用户启动接口、设置IP地址、查看连接和路由信息。不同发行版可能有差异,建议参考相应文档。
19 4
|
1天前
|
安全 Linux 开发工具
Linux中可引起文件时间戳改变的相关命令
【4月更文挑战第12天】Linux中可引起文件时间戳改变的相关命令
9 0
|
3天前
|
Linux Shell 开发工具
Linux文件常用操作
Linux文件常用操作(几乎覆盖所有日常使用)
58 0