linux 网络配置
linux的网络服务是由内核提供。
网卡在内核看来就是个设备,各种网络配置不在网卡上。各种配置都是针相应网络管理程序使用的。
不同发行版的网络管理工具也是不一样(net-tools/iproute)。网络服务的管理程序(守护进程)也是不一样(脚本/程序)。
网络管理工具是将用户的设定直接传递给内核的网络服务,及时有效。
很多管理工具可以及时生效,都是对内核操作,一般只有管理员有权限。修改配置用文件永久有效,但是不是及时生效,可重启网络服务或主机。
-
网络管理工具
-
网络配置文件
-
网络服务
-
网卡别名
centos网络管理工具
net-tools
[root@centos7 ~]# whereis ifconfig
ifconfig: /usr/sbin/ifconfig /usr/share/man/man8/ifconfig.8.gz
[root@centos7 ~]# rpm -qf /usr/sbin/ifconfig
net-tools-2.0-0.17.20131004git.el7.x86_64
[root@centos7 ~]# rpm -ql net-tools/bin/netstat
/sbin/arp
/sbin/ether-wake
/sbin/ifconfig
/sbin/ipmaddr
/sbin/iptunnel
/sbin/mii-diag
/sbin/mii-tool
/sbin/nameif
/sbin/plipconfig
/sbin/route
/sbin/slattach
iproute 出现的目的是代替net-tools
/usr/sbin/arpd
/usr/sbin/bridge
/usr/sbin/cbq
/usr/sbin/ctstat
/usr/sbin/genl
/usr/sbin/ifcfg
/usr/sbin/ifstat
/usr/sbin/ip
/usr/sbin/lnstat
/usr/sbin/nstat
/usr/sbin/routef
/usr/sbin/routel
/usr/sbin/rtacct
/usr/sbin/rtmon
/usr/sbin/rtpr
/usr/sbin/rtstat
/usr/sbin/ss
/usr/sbin/tc
命令行下的字符界面管理工具
setuptool
命令 setup
/e> tc/setuptool.d/98netconfig
/etc/setuptool.d/98system-config-authentication
/etc/setuptool.d/98system-config-display
/etc/setuptool.d/98system-config-keyboard
/etc/setuptool.d/99Xconfigurator
/etc/setuptool.d/99authconfig
/etc/setuptool.d/99kbdconfig
/etc/setuptool.d/99mouseconfig
/etc/setuptool.d/99ntsysv
/etc/setuptool.d/99printconf-tui
/etc/setuptool.d/99sndconfig
/etc/setuptool.d/99system-config-firewall-tui
/etc/setuptool.d/99system-config-network-tui
/etc/setuptool.d/99timeconfig
/usr/bin/setup
/usr/sbin/setup
centos网络配置文件
配置文件可手动修改(vim)也可以使用命令修改。
可修改配置文件的命令
centos6:system-config-network(setup);cenos7:nmtul
接口配置文件
路由配置文件
hosts主机名称解析配置文件
网络接口的配置文件(网卡)
/etc/sysconfig/network-scripts/ifcfg-INTERFACE
IP、MASK、GW、DNS相关配置
该文件通过大量参数来定义接口的属性;其可通过vim等文本编辑器直接修改,也可以使用专用的命令修改,(centos6:system-config-network(setup),cenos7:nmtui)添加设备后,需要启动该设备,可以手动创建配置文件,或者使用命令 setup/nmtul
一个网络接口可以设置多个ip,需要使用别名(lable)。
setup 文字图形界面
[root@centos7 ~]# rpm -qf /usr/bin/setup setuptool-1.19.11-8.el7.x86_64
nmtui(文字图形界面)/nmcli—-是工具软件
[root@centos7 ~]# rpm -qf /usr/bin/nmcli NetworkManager-1.0.6-27.el7.x86_64
路由配置文件
/etc/sysconfig/network-scripts/rote-INTERFACE
要用到非默认网关路由,支持两种配置风格,不可混用。
1)每行一个路由条目 目标地址 via 下一跳 2)每三行一个路由条目,#为序号 ADDRESS#= NETMASK#= GATEWAY#=
修改配置文件不会立即生效,需要重启网络服务才能生效。
DNS配置文件
/etc/resolv.conf
[root@centos7 ~]# cat /etc/resolv.conf
# Generated by NetworkManager search magedu.com localdomain nameserver 10.1.0.1 nameserver 192.168.154.1 /etc/nsswitch.conf 与/etc/hosts相比优先于DNS
主机名配置文件
/etc/sysconfig/network
本地主机houstname配置文件/etc/sysconfig/network 格式 HOSTNAME=mageedu.com 修改主机名配置文件后,只有重新开启新终端,或重启服务器才可以生效。或使用命令修改 实例: [root@centos6 ~]# cat /etc/sysconfig/network ###centos6 NETWORKING=yes ###是否开启网络服务 HOSTNAME=yangyouwei.centos6 GATEWAY= ###也可以定义网关,范围是全局的。但是同时网卡的配置文件也定义了网关,那么只是网卡的网关生效。
hosts配置文件—–解析其他其他主机用的
本地解析器
解析器执行正向和逆向查询 ——————解析其他主机的主机名。 /etc/hosts •本地主机名数据库和IP地址的映像 •对小型独立网络有用 •通常,在使用DNS前检查 •getent hosts 查看/etc/hosts 内容 配置文件格式, 192.168.1.1 www.mageedu.com www mage mageedu magedu 可设置主机名和多个别名。中间用空格隔开。 DNS解析过程,先访问本地hosts文件,文件中没有才组查找DNS配置文件(resolv.conf)
网络服务
随系统启动,启动后读取配置文件,将网络配置的参数传递给内核。
centos5、6都使用network服务
centos6还是用NetManager服务(但是不稳定,不建议使用,在网卡配置文件中可以禁止使用该服务。)NeworkManager是管理和监控网络设置的守护进程
centos7使用NetworkManager 也支持使用network
修改了配置文件,要重启网络服才能立即生效。
服务管理
centos6:service SERVICE {start|stop|restart|status}
centos7:也支持使用service
实际使用的是 systemctl {start|stop|restart|status} SERVICE[.service]
查看开启了那些服务
[root@centos7 ~]# chkconfig --list Note: This output shows SysV services only and does not include native systemd services. SysV configuration data might be overridden by native systemd configuration. If you want to list systemd services use 'systemctl list-unit-files'. To see services enabled on particular target use 'systemctl list-dependencies [target]'. netconsole 0:off 1:off 2:off 3:off 4:off 5:off 6:off network 0:off 1:off 2:on 3:on 4:on 5:on 6:off
网络设备名称
网络管理软件一般都是针对网卡名称,对网卡操作。所以网卡名称很关键。在配置文件中也不要写错。
网卡设备名称,类似硬盘的/dev/sda…的作用。不应该有重名的
网卡别名
一个网络接口可以配置多个ip,对虚拟主机有用
有多个ip地址的网络接口,对应的设备及ip要有lable(别名),ifconfig才能够识别。
使用命令配置网卡别名
将多个IP地址绑定到一个NIC上,别名的网卡不能使用DHCP服务。必须手动配置地址。
eth0:1
eth0:2
eth0:3
ifconfig命令: ifconfig eth0:0 192.168.1.100/24 up ip命令: ip addr add 172.16.1.2/16 dev eth0 ip addr add 172.16.1.1/16 dev eth0 label eth0:0 ip addr del 172.16.1.1/16 dev eth0 label eth0:0 ip addr flush dev eth0 label eth0:0
手动编写配置文件
为每个设备别名生成独立的接口配置文件 •关闭NetworkManager服务 •ifcfg-ethX:xxx •必须使用静态联网 DEVICE=eth0:0 名称必须与文件名一致 IPADDR=10.10.10.10 NETMASK=255.0.0.0 ONPARENT=yes 注意:service network restart 生效 参考/usr/share/doc/initscripts-*/sysconfig.txt 网络接口识别并命名相关的udev配置文件: /etc/udev/rules.d/70-persistent-net.rules 卸载网卡驱动: modprobe-r e1000 装载网卡驱动: modprobe e1000
eth0, eth1这些名称是怎么来的呢?
内核发现一个pci网卡设备,调用网卡驱动的probe函数。
probe函数在做完一定的初始化之后,会调用内核接口register_netdev向内核注册一个新的net_device设备。
这个设备的名字,网卡驱动程序往往只决定其中一部分。
就像下面这种方式,网卡驱动提供一个“eth%d”这样的名称,然后调用内核接口register_netdev。
strcpy(netdev->name, "eth%d");
register_netdev(netdev);
register_netdev流程中,会根据系统中已有的接口情况,找出一个最小的还没有使用的数字编号,分给新注册的网卡。
比如,系统中当前有,eth0, eth2, eth3三块网卡。
那么新注册的网卡,名字就是eth1了。
当然,网卡驱动也可以提供完整的名字,但必须保证名字与现有网卡不冲突。
这在驱动中就不好实现了。而且,一个驱动程序,可能会驱动很多块网卡,怎么起名字,都是个问题。
最后,用户态程序,可以通过ioctl系统调用,去修改网卡的名称。
Linux中总线、设备、驱动这3者是非常重要的数据结构,它们互相之间都有联系一旦一个设备和一个驱动能够匹配上,就会执行驱动里的probe。
prpbe 探针
总之一句话,probe函数作为driver的最基本的函数指针,一旦你的device和driver匹配(match,由总(bus)来完成,匹配工作发生在device_register()和drvier_register()的时候),probe函数就肯定会被调用;而probe的参数,pci里是struct pci_dev *pdev ,这个是由linux内核启动时遍历pci总线后得到的pci设备的描述符。
probe调用期间一般会完成device的初始化,注册中断等操作。
原创文章,作者:yyw,如若转载,请注明出处:http://www.178linux.com/44955