Linux网络设置
一、查看网络配置1.查看网络接口信息ifconfig查看所有活动的网络接口信息执行ifconfig命令ens33:第一块以太网卡的名称。“ens33”中的“en”是“EtherNet”的缩写,表示网卡类型为以太网,“s”表示热插拔插槽上的设备(hot-plug Slot),数字“33”表示插槽编号。lo:“回环”网络接口,“lo”是“loopback”的缩写,它不代表真正的网络接口,而是一个虚拟的
目录
3.ip route show=ip route #查看路由配置
2.建议关闭NetworkManager服务,否则有时启动network会报错
引言:
linux网络设置是服务的基础,只有打好基础,了解各个基础问题才能建立好的服务。故此介绍一些网络的基本配置。
一、查看网络配置
1.查看网络接口信息ifconfig
查看所有活动的网络接口信息
执行ifconfig命令
ens33:第一块以太网卡的名称。“ens33”中的“en”是“EtherNet”的缩写,表示网卡类型为以太网,“s”表示热插拔插槽上的设备(hot-plug Slot),数字“33”表示插槽编号。
lo:“回环”网络接口,“lo”是“loopback”的缩写,它不代表真正的网络接口,而是一个虚拟的网络接口,其 IP 地址默认是“127.0.0.1”,子网掩码为8位,表示本机。用来测试一个网络程序,但又不想让局域网或外网的用户能够查看,只能在此台主机上运行和查看所用的网络接口。比如把 HTTPD服务器的指定到回坏地址,在浏览器输入 127.0.0.1 就能看到你所架WEB网站了。但只是您能看得到,局域网的其它主机或用户无从知道
virbr0:是一个虚拟的网络连接端口,默认为0号虚拟网络连接端口;一般在通过虚拟机进行移植操作系统时,默认会以nat的网络地址转移,但是可以选择桥接或者是无网络连接也是可以的(因为本人用的是centos镜像的虚拟机,所以会有这一行)
主机的网络接口卡(网卡)通常称为网络接口。在 Linux 操作系统中,使用 ifconfig 命令可以查看网络接口的地址配置信息(Interface Configuration)
查看指定网络接口信息
ifconfig 网络接口
ens33:第一块网卡的名称(33是网卡编号)
inet:IP地址
netmask:子网掩码
broadcast:广播地址
添加临时网卡IP:ifconfig ens33:1 192.168.223.50
临时修改网卡IP:
ifconfig ens33 192.168.223.11/24
或 ifconfig ens33 192.168.223.11 netmask 255.255.255.0
重启网卡后恢复原先ip
ifdown ens37#关闭某个网卡
ifup ens37#启动某个网卡
ifconfig ens37 down #临时禁用某个网卡
ifconfig ens37 up #重新激活某个网卡(不会更新IP地址)
2.查看主机名称 hostname
主机名:在 Linux 操作系统中,相当一部分网络服务都会通过主机名来识别主机,如果主机名配置不当,可能会导致程序功能出现故障
查看当前主机的完整名称
hostname
临时设置主机名
hostname 主机名
永久设置主机名
hostnamectl set-hostname 主机名
或vim /etc/hostname(设置完后需重启系统才生效)
按i键先删除旧主机名,再输入新主机名(只有第一行有效)
3.查看路由表条目 route
1.route命令
查看或设置主机中路由表信息
当目标网段为“default”时,表示此行是默认网关记录;
当下一跳为“gateway”时,表示目标网段是与本机直接相连的。
但是,直接执行“route”命令无法直接看出默认网关地址
2.route [-n]
查看路由,使用-n可以将路由记录中的地址显示为数字形式,这可以跳过解析主机名的过程,在路由表条目较多的情况下能够加快执行速度
Destination 列对应目标网段的地址
Gateway 列对应下一跳路由器的地址
Iface 列对应发送数据的网络接口
3.ip route show=ip route #查看路由配置
4.添加静态路由条目
临时添加路由(重启network服务失效)‘
方法一:
route add -net 192.168.200.0/24 gw 192.168.223.1
-net:指定目标网段的地址
gw:指定下一跳路由器的 IP 地址
dev: 为路由指定的输出接口
删除静态路由条目
route del -net 192.168.200.0/24
重启网卡后失效
方法二:
ip route add 192.168.200.0/24 via 192.168.223.1
永久添加路由(重启network服务生效)
重启网卡后失效
删除静态路由条目
默认路由设置
4.查看网络连接情况netstat
netstat命令
查看系统的网络连接状态、路由表、接口统计等信息
netstat [选项]
常用参数
-n :以数字的形式显示相关的主机地址、端口等信息
-r :显示路由表信息
-a :显示主机中所有活动的网络连接信息(包括监听、非监听状态的服务端口)
-l :显示处于监听(Listening)状态的网络连接及端口信息。
-t :查看 TCP(Transmission Control Protocol,传输控制协议)相关的信息。
-u :显示 UDP(User Datagram Protocol,用户数据报协议)协议相关的信息。
-p :显示与网络连接相关联的进程号、进程名称信息(该选项需要 root 权限)
Proto显示连接使用的协议,
RefCnt表示连接到本套接口上的进程数量,
Types显示套接口的类型,
State显示套接口当前的状态,
Path表示连接到套接口的其它进程使用的路径名
用法:
①通常使用“-anpt”组合选项,以数字形式显示当前系统中所有的 TCP 连接信息,同时显示对应的进程信息
②配合管道符grep过滤出特定的记录
5.获取socket统计信息ss
ss命令
查看系统的网络连接情况,获取socket统计信息
ss [选项]
常用参数
-h: 通过该选项获取更多的使用帮助。
-V: 显示软件的版本号。
-t: 显示 TCP 协议的 sockets。
-u: 显示 UDP 协议的 sockets。
-n: 不解析服务的名称,如 "22" 端口不会显示成 "ssh"。
-l: 只显示处于监听状态的端口。
-p: 显示监听端口的进程。
-a: 对 TCP 协议来说,既包含监听的端口,也包含建立的连接。
-r: 把 IP 解释为域名,把端口号解释为协议名称。
-o: 选项可用于显示计时器信息。该信息向我们展示了诸如重新传输计时器值、已经发生
的重新传输的数量以及已发送的keepalive探测的数量
-w: 用于字符串精确匹配
ss 命令:也可以查看网络连接情况,主要用于获取 socket 统计信息,它可以显示和 netstat 命令类似的输出内容。但 ss 的优势在于它能够显示更多更详细的有关 TCP 和连接状态的信息,而且比 netstat 更快速更高效。要想使用ss命令是Linux CentOS7中iproute软件包的一部分,默认已经安装,如果没安装,额可以通过yum安装(几乎所有的Linux系统都会默认包含netstat命令,但并非所有系统都会默认包含ss命令。)
6.time命令:测量命令的执行时间或者系统资源的使用情况
(1) real:从进程1s开始执行到完成所耗费的cPU_总时间。该时间包括_1s进程执行时实际使用的CPU时间,1s进程耗费在阻塞上的时间(如等待完成I/o操作)和其他进程所耗费的时间(Linux是多进程系统,1s在执行过程中,可能会有别的进程抢占CPu) 。
(2) user:进程1s执行用户态代码所耗费的cPU时间。该时间仅指 1s 进程执行时实际使用的cPU时间,而不包括其他进程所使用的时间和本进程阻塞的时间。
(3) sys:进程 1s 在内核态运行所耗费的 cPü时间,即执行内核系统调用所耗费的 cPU时间。现在,我们应该对这三个时间非常清楚了吧。1s 命令的真正执行时间是多少﹖答案就是user+sys的时间,但一般情况下,real=user+sys,因而我们就使用real 的时间作为 1s 的执行时间了
7.netstat和ss的区别
ss命令用来替代netstat的,可以用来获取socket统计信息,它可以显示和netstat类似的内容。
ss的优势在于它能够显示更多更详细的有关TCP和连接状态的信息,而且比netstat更快速更高效。
1.ss快捷高效
ss比netstat快的主要原因是,netstat是遍历/proc下面每个PID目录,ss直接读/proc/net下面的统计信息。所以ss执行的时候消耗资源以及消耗的时间都比netstat少很多。
当服务器的socket连接数量非常大时(如上万个),无论是使用netstat命令还是直接cat /proc/net/tcp执行速度都会很慢,相比之下ss可以节省很多时间。ss快的秘诀在于,它利用了TCP协议栈中tcp_diag,这是一个用于分析统计的模块,可以获得Linux内核中的第一手信息。如果系统中没有tcp_diag,ss也可以正常运行,只是效率会变得稍微慢但仍然比netstat要快。
由输出结果显示,ss的速度比netstat快
2.输出结果
ss -atn结果:
netstat -atn结果:
- netstat将state放在最后一列,而ss将其放在第一列,
- ss能够显示更多更详细的有关TCP和连接状态的信息,
- ss增加了Port(端口类型)
二、测试网络连接 ping
ping命令
测试网络连通性
ping[选项]目标主机
使用ping命令可以向目标主机持续地发送测试数据包,并显示反馈结果,直到按ctrl +c组合键后中止测试,并显示最终统计结果
1.ping 192.168.245.201 #最常用是后面跟ip地址和域名
2.-c表示指定ping的次数
3.-i秒数:设定间隔几秒送一个网络封包给一台机器,预设值是一秒送一次。
4.-w表示ping的超时时间为5s,意思是只ping5秒,5秒后结束
若看到"Destination Host Unreachable"的反馈信息,则表示目的主机不可达,可能目标地址不存在或者主机已经关闭若看到"Network is unreachable"的反馈信息,则表示没有可用的路由记录(如默认网关),无法达到目标主机所在的网络。当目标主机有严格的防火墙限制时,或者当网络中存在影响通信过程稳定性的因素(如网卡故障、病毒或网络攻击等)时,可能收到Request timeout”的反馈结果。
三、跟踪数据包traceroute
traceroute命令
测试从当前主机到目的主机之间经过的网络节点
traceroute 目标主机地址
traceroute命令能够比 ping 命令更加准确地定位网络连接的故障点(中断点),因此执行速度会比 ping 命令稍慢。在网络测试与排错过程中,通常会先使用 ping 命令测试与目的主机的网络连接,如果发现网络连接有故障,再使用traceroute命令跟踪查看是在哪个中间结点存在故障。
四、域名解析nslookup
1.nslookup命令
测试DNS域名解析
nslookup 目标主机地址 [DNS服务器地址]
2.建议关闭NetworkManager服务,否则有时启动network会报错
systemctl stop NetworkManager
systemctl disable NetworkManager
3.域名解析配置文件查看与修改 resolv.conf
resolv.conf 文件中的“search localdomain”行用来设置默认的搜索域(域名扩展名)。 例如,当访问主机“localhost”时,就相当于访问“localhost.localdomain”。
/etc/resolv.conf 文件中记录了本机默认使用的 DNS 服务器的地址信息,对该文件所做 的修改将会立刻生效。Linux 操作系统中一行一个DNS,最多可以指定 3 个(第 3 个以后的将被忽略)不同 的 DNS 服务器地址,优先使用第一个 DNS 服务器。
注意:CentOS 7需要在NetworkManager.conf文件main段内设置dns=none,并重启NetworkManager服务,或者使用CentOS7新添加nmcti命令进行设置
4.本地主机映射文件
etc/hosts 文件中记录着一份主机名与 IP 地址的映射关系表,一般用来保存经常需要访问的主机的信息。当访问一个未知的域名时,先查找该文件中是否有相应的映射记录,如果找不到再去向 DNS 服务器查询。
若在/etc/hosts 文件中添加“192.168.233.9 www.lichen.com”的映射记录,则当访问网站 www.baidu.com 时,将会直接向 IP 地址 192.168.223.9www.lichen.com 发送 Web 请求。
vim /etc/hosts
hosts文件和DNS服务器的比较
默认情况下,系统首先从hosts文件查找解析记录
hosts文件只对当前的主机有效
hosts文件可减少DNS查询过程,从而加快访问速度
五、设置网络参数的方式
临时配置——使用命令调整网络参数
简单、快速,可直接修改运行中的网络参数
—般只适合在调试网络的过程中使用
系统重启以后,所做的修改将会失效
固定设置——通过配置文件修改网络参数
修改各项网络参数的配置文件
适合对服务器设置固定参数时使用
营重奉载网络服务或者重启以后才会生效
六、总结
查看网络配置
ifconfig、hostname、route、netstat、ss
测试网络连接
ping.traceroute、nslookup、dig
设置网络地址参数
临时配置、永久配置
更多推荐
所有评论(0)