网络总结

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

(0)
yywyyw
上一篇 2016-09-09
下一篇 2016-09-09

相关推荐

  • 软件包管理工具—rpm命令总结

    描述:    RPM是RedHatPackageManager的缩写,是由RedHat公司开发的软件包安装和管理程序,同Windows平台上的Uninstaller比较类似。使用RPM,用户可以自行安装和管理Linux上的应用程序和系统工具。RPM可以让用户直接以binary方式安装软件包,并且可替用户查询是否已经安装了有关的库文件;在用…

    Linux干货 2016-08-29
  • 构建一个高可用的Nginx集群

    实验目的: 构建一个高可用的Nginx集群。 实验要求: 1、基于nat结构实现; 2、实现高可用; 实验拓扑图形: 实验步骤: 1、  按图配置各个网卡地址; 2、  设置Nginx主机(下面带#的部分为从所需要的配置,其他则一样) Yum install httpd nginx Vim /etc/httpd/conf/httpd.co…

    2017-05-15
  • 利用heartbeat v2版搭建高可用mysql

    一、实验环境  1)实验图        2)同步时间;确保可以使用主机名通信;确保可以使用ssh秘钥方式进行彼此登录;由于是两台设备,需要仲裁;  确保可以使用主机名通信 web1修改hosts文件如下: 172.16.2.12 SQL1.linux.com SQL1 172.…

    Linux干货 2015-07-08
  • ​redis cluster 安装指南

    公司的很多项目在使用redis主从。由于coder的各种毁灭性操作,迫切需要一个能带故障恢复的架构。因此新版的cluster,开始了测试。 一、Cluster 理论基础 Cluster介绍 Redis集群是一个提供在多个Redis间节点间共享数据的程序集。 Redis集群并不支持处理多个keys的命令,因为这需要在不同的节点间移动数据,从而达不到像Redis…

    Linux干货 2016-02-14
  • 27期第一周学习小结

    第一周 1. 描述计算机的组成及其功能。 计算机主要组成部分以下五种:运算器,控制器,存储器,输入设备,输出设备。 运算器的功能是对数据进行算术运算与逻辑运算,就是对数据进行加工处理。 控制器的功能是调度二进制程序,数据,内存寻址,以及协调计算机输入设备和输出设备等各计算机部件之间的正常工作。 存储器的功能是存储二进制指令和数据。存储器是编址存储单元。 输入…

    Linux干货 2017-07-15