一.网卡名字修改
1.网卡命名规则
- CentOS6之前基于传统的命名方式如: eth1, eth0....
- Centos7提供了不同的命名规则,默认是基于固件、拓扑、位置信息来分配
- 这样做的优点是命名是全自动的、可预知的,缺点是比eth0更难读, 比如ens33
2.网卡命名策略(了解)
3.配置网卡命名的方式
⛅为了方便先进到目录,改成你想要的名字
[root@shawn ~]#cd /etc/sysconfig/network-scripts/
[root@shawn network-scripts]#mv ifcfg-ens32 ifcfg-eth100
⛅直接使用"sed"查找后替换掉
[root@shawn network-scripts]#sed -i "s/ens32/eth100/g" ifcfg-eth100
⛅或者进配置文件进行修改
[root@shawn network-scripts]#vim ifcfg-eth100
⛅进入内核参数文件
[root@shawn network-scripts]#vim /etc/sysconfig/grub
⛅修改这一行,"100"
GRUB_CMDLINE_LINUX="rhgb quiet 'net.ifnames=100 biosdevname=100'"
⛅加载到引导分区,生成菜单
[root@shawn network-scripts]#grub2-mkconfig -o /boot/grub2/grub.cfg
⛅重启系统生效,再查看是否成功
[root@shawn network-scripts]#reboot
[root@shawn ~]#ifconfig
eth100: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 #发现已经改变了
二.基本网络配置
1.查看网卡连接状态
⛅查看当前系统所连接的所有网卡 (我这里只有一个网卡,所以显示一个)
[root@shawn ~]#lspci | grep -i eth
02:00.0 Ethernet controller: Intel Corporation 82545EM Gigabit Ethernet Controller (Copper) (rev 01)
⛅确认网卡是否连接(link ok 表示网卡能被识别,并且接了有效的网线)
[root@shawn ~]#mii-tool eth100
eth100: negotiated 1000baseT-FD flow-control, link ok
⛅如果显示"failed: .....",则代表网线没连接等等
2.ifconfig
命令
⛅查看
ifconfig -a #查看所有网卡信息
ifconfif eth100 #查看指定网卡信息
⛅配置,添加子接口
ifconfig eth100 192.168.12.188/24 #临时设置IP和掩码(重启服务或系统都失效)
ifconfig eth100 192.168.12.188 netmask 255.255.255.0 #同上一样
ifconfig eth100:1 192.168.12.199/24 #配置子接口
⛅删除子接口
ifconfig eth100:1 down #删除这个子接口
ifconfig eth100:1 del 192.168.12.199 #删除这个子接口
⛅开启与关闭网卡配置
ifconfig eth100 down/up #不加载/加载这个网卡的配置文件
ifdown eth100 / ifup eth100 #不加载/加载这个网卡的配置文件
⛅设置网卡最大传输单元
ifconfig eth0 mtu 1500
⛅开启和关闭模式(了解)
ifconfig eth0 promisc #开启繁杂模式
ifconfig eth0 -promisc #关闭繁杂模式
ifconfig eth0 multicast #开启多播
ifconfig eth0 -multicast #关闭多播
ifconfig eth0 allmulti #开启
ifconfig eth0 -allmulti #关闭
⛅添加删除"ipv6"地址
ifconfig eth0 add 3ffe:3240:800:1005: :2/64
ifconfig eth0 del 3ffe:3240:800:1005: :2/64
3.ifconfig 查看结果解释
[root@shawn ~]#ifconfig
ens32: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
# [表示接口已启用] [表示主机支持广播] [表示接口在工作中] [表示主机支持多播] [mtu:1500最大传输单元(字节)]
inet 192.168.12.188 netmask 255.255.255.0 broadcast 192.168.12.255
#IPV4地址 #子网掩码 #广播地址
inet6 fe80::20c:29ff:fe93:fdc8 prefixlen 64 scopeid 0x20<link>
#IPV6地址 #掩码长度 #作用域, link表示仅该接口有效
ether 00:0c:29:93:fd:c8 txqueuelen 1000 (Ethernet)
#网口接口的MAC地址 #传输队列长度 #接口类型
RX packets 192442 bytes 23005768 (21.9 MiB)
#表示此接口接收到的报文个数,总字节数
RX errors 0 dropped 3378 overruns 0 frame 0
#接收报文错误数,丢弃数,溢出数(由于速度过快而丢失的数据包),冲突的帧数
TX packets 441431 bytes 34287197 (32.6 MiB)
#表示此接口发送的报文个数,总字节数
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
#发送报文错误数,丢弃数,溢出数(由于速度过快而丢失的数据包),载荷数(发生carrier错误而丢失的数据包),冲突的帧数
⛅全双工传输英文写法是:Full - Duplex Transmissions
是指交换机在发送数据的同时也能够接收数据,两者同步进行
这好像我们平时打电话一样,说话的同时也能够听到对方的声音,目前的交换机都支持全双工。
全双工的好处在于迟延小、冲突少、速度快
⛅半双工:就是指一个时间段内只有一个动作发生,
举个简单例子,一条窄窄的马路,同时只能有一辆车通过,当目前有两量车对开,这种情况下就只能一辆先过,等到头儿后另一辆再开
这个例子就形象的说明了半双工的原理
早期的对讲机、以及早期集线器等设备都是实行半双工的产品
随着技术的不断进步,半双工会逐渐退出历史舞台
⛅CRC即循环冗余校验码(Cyclic Redundancy Check)
是数据通信领域中最常用的一种查错校验码,其特征是信息字段和校验字段的长度可以任意选定
循环冗余检查(CRC)是一种数据传输检错功能
对数据进行多项式计算,并将得到的结果附在帧的后面,接收设备也执行类似的算法,以保证数据传
输的正确性和完整性
⛅网卡发包
1、"ip"包 + 14 个字节的"mac"头变成数据帧"frame"
2、"frame"拷贝到网卡芯片内部的缓冲区,由网卡处理
3、网卡芯片为"frame"添加头部同步信息和"CRC"校验,此时才是真正可以发送的"packet",然后发送
该"packet"
⛅网卡收包
1、网络包"packet"到达网卡,网卡先检查包"packet"的"CRC"校验,保证其完整性和正确性,然后去掉它的头得到"frame"
2、网卡将"frame"拷贝到网卡内部的"FIFO"缓冲区
3、网卡驱动程序产生硬件中断,把"frame"从网卡拷贝到内存中,接下来就交给内核处理
⛅网卡丢包
1.内核通常需要快速的拷贝网络数据包到系统内存
2.因为网卡上接收网络数据包的缓存大小固定,而且相比系统内存也要小得多
3.所以上述拷贝动作一旦被延迟, 必然造成网卡FIFO缓存溢出-进入的数据包占满了网卡的缓存
4.后续的包只能被丢弃,这也应该就是"ifconfig"里的"overrun"的来源。
⛅丢包排查
网卡工作在数据链路层,数据量链路层,会做一些校验,封装成帧
我们可以查看校验是否出错,确定传输是否存在问题。然后从软件层面,是否因为缓冲区太小丢包
⛅先查看底层硬件情况
🌞查看工作模式是否正常
[root@shawn ~]#ethtool ens32 | egrep 'Speed|Duplex'
Speed: 1000Mb/s
Duplex: Full
🌞查看CRC校验是否正常
[root@shawn ~]#ethtool -S ens32 | grep crc
rx_crc_errors: 0
#出现 Speed, Duplex, CRC 之类的都没问题,基本可以排除物理层面的干扰
⛅通过"ifconfig"可以看到"overruns"是否一直增大,如果查看结果是一直增大
🌞先查看网卡缓冲区
[root@shawn ~]#ethtool -g ens32
Ring parameters for ens32:
Pre-set maximums: #最大可设置的值
RX: 4096
RX Mini: 0
RX Jumbo: 0
TX: 4096
Current hardware settings: #当前设置的值
RX: 256
RX Mini: 0
RX Jumbo: 0
TX: 256
🌞进行调大,并再次查看
[root@shawn ~]#ethtool -G ens32 rx 2048 (增大)
[root@shawn ~]#ethtool -G ens32 tx 2048 (增大)
[root@shawn ~]#ethtool -g ens32
Ring parameters for ens32:
Pre-set maximums:
RX: 4096
RX Mini: 0
RX Jumbo: 0
TX: 4096
Current hardware settings:
RX: 2048 #可以发现变大了
RX Mini: 0
RX Jumbo: 0
TX: 2048
[root@shawn ~]#ethtool -s ens32 speed 100 duplex full
[root@shawn ~]#ethtool -s ens32 speed 100 duplex full autoneg off #关闭自适应才能设置成功
[root@shawn ~]#ethtool ens32 #查看
⛅若想完成永久设置,可以将上述"ethtool"设置写入/"etc/rc.d/rc.local"之中
🌞然后记住必须要加一个x权限
[root@shawn ~]# chmod +x /etc/rc.d/rc.local
6.ping
命令
⛅测试两台主机网络是否通
1. ping [目标IP地址] #Ctrl + c 结束
2. ping -c [次数] [目标IP地址] #设置"ping"的次数
⛅禁止别人"ping"自己
# echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all
7.关闭NetworkManager
服务
- NetworkManager是检测网络、自动连接网络的程序
- 网络管理器最初由 Redhat 公司开发,现在由 GNOME 管理
- 它会干扰网络配置, 比如: DNS经常被刷掉, 所以通常关闭
[root@shawn ~]#systemctl stop NetworkManager (关闭)
[root@shawn ~]#systemctl disable NetworkManager (开机不重启)
8./etc/sysconfig/network-script/ifcfg-xxx
配置文件相关信息
9.dns
配置文件
⛅可以设置DNS指向,最多三个
[root@shawn ~]#cat /etc/resolv.conf
nameserver 8.8.8.8 #对应的是网卡配置文件中的第一个NDS配置项
nameserver 223.6.6.6 #对应的是网卡配置文件中的第二个NDS配置项
/etc/hosts
本地名称解析文件, 优先于DNS
⛅DNS检索优先级
浏览器缓存--->本地系统缓存--->本地计算机HOSTS文件--->ISP远程DNS--->递归or迭代搜索
10.永久设置主机名
⛅通过修改文件来永久修改主机名
[root@localhost ~]# vi /etc/hostname
⛅通过命令的方式也是永久修改
[root@localhost ~]# hostnamectl set-hostname [想要的主机名]
[root@localhost ~]# exit
登出
⛅重新登入即可
11.查看端口与服务的对应关系
[root@shawn ~]#grep '^ftp\|^ssh' /etc/services