linux网络追踪的命令 linux中追踪路由

Linux系统中tracert命令使用详解Linux系统中Tracert命令用来显示数据包到达目标主机是所经过的路径 。下面由我为大家整理了linux系统中tracert命令使用详解,希望对大家有帮助!
Linux系统中tracert命令使用详解
Tracert命令用来显示数据包到达目标主机所经过的路径,并显示到达每个节点的时间 。命令功能同Ping类似,但它所获得的信息要比Ping命令详细得多 , 它把数据包所走的全部路径、节点的IP以及花费的时间都显示出来 。该命令比较适用于大型网络 。
命令格式:
tracert IP地址或主机名 [-d][-h maximumhops][-j host_list] [-w timeout]
参数含义:
-d 不解析目标主机的名字;
-h maximum_hops 指定搜索到目标地址的最大跳跃数;
-j host_list 按照主机列表中的地址释放源路由;
-w timeout 指定超时时间间隔,程序默认的时间单位是毫秒 。
linux系统中tracert命令用法
tracert [-d] [-h maximum_hops] [-j computer-list] [-w timeout] target_name
如果不使用参数,将显示连接情况 , 如图2-23所示 。
提示:
图2-23显示的是从本地计算机到163这台服务器所经过的计算机 。
● -d
指定不将地址解析为计算机名,如图2-24所示 。
● -h maximum_hops
指定搜索目标的最大跃点数,如图2-25所示 。
● -j computer-list
指定沿computer-list的稀疏源路由 。
● -w timeout
每次应答等待timeout指定的微秒数,如图2-26所示 。
补充:linux系统中tracert命令原理
tracert命令也称作路由跟踪命令,用于确定IP数据库包访问目标所采取的路径,通过IP生成时间(TTL)字段和ICMP错误信息来确定 , 从个网络到主机之间的网络状况 。
tracert命令原理与ping命令为相似,都是通过向目标发送数据包,并通过数据包响应及丢失情况,从而判断本地与目标主机之间的网络状况,所不同的是tracert命令能够反映出网络中各个路由节点信息,以及网络状况,并且可以用以跟踪路由节点,以及监控服务器状况等作用 。
linux下tracert命令的作用1.命令格式:
traceroute [参数] [主机]
2.命令功能:
traceroute指令让你追踪网络数据包的路由途径,预设数据包大小是40Bytes,用户可另行设置 。
具体参数格式:traceroute [-dFlnrvx][-f存活数值][-g网关…][-i网络界面][-m存活数值][-p通信端口][-s来源地址][-t服务类型][-w超时秒数][主机名称或IP地址][数据包大小]《Linux就该这么学》 一起学习linux
3.命令参数:
-d 使用Socket层级的排错功能 。
-f 设置第一个检测数据包的存活数值TTL的大小 。
-F 设置勿离断位 。
-g 设置来源路由网关 , 最多可设置8个 。
-i 使用指定的网络界面送出数据包 。
-I 使用ICMP回应取代UDP资料信息 。
-m 设置检测数据包的最大存活数值TTL的大小 。
-n 直接使用IP地址而非主机名称 。
-p 设置UDP传输协议的通信端口 。
-r 忽略普通的Routing Table,直接将数据包送到远端主机上 。
-s 设置本地主机送出数据包的IP地址 。
-t 设置检测数据包的TOS数值 。
-v 详细显示指令的执行过程 。
-w 设置等待远端主机回报的时间 。
-x 开启或关闭数据包的正确性检验 。
4 实例:
实例4.1 : traceroute
实例4.2:跳数设置
命令:traceroute -m 10
linux系统怎么ping网络在Linux系统中使用命令"ping 网址"可以ping网络 。例如 , 使用"ping "可以ping网站 。
拓展:除了ping网络,Linux系统还可以使用traceroute命令来查看网络路径 。使用该命令可以追踪从主机到另一个主机之间的路由,并显示每个路由中经过的主机列表 。
Linux检测网络连通情况的命令?在 Linux 中,可以使用 'ping命令会向指定的主机发送 ICMP 回显请求 , 并接收响应 。如果主机响应了请求 , 则表示与该主机之间的网络连通性良好 。
例如,要检测主机 192.168.1.1 的网络连通性,可以使用以下命令:
运行该命令后,系统会向 192.168.1.1 发送 ICMP 回显请求,并在接收到响应后打印输出信息 。如果网络连通性良好,则会看到类似于以下信息的输出:
如果网络连通性不佳,则会看到类似于以下信息的输出:
Linux常用网络配置命令一、查看网络配置
确保网络配置的正确性及网络连接的畅通是Linux系统作为服务器应用的基础,查看及测试网络配置是管理Linux网络服务的第一步 。
1.ifconfig——查看网络配置
1) 查看所有活动网络接口的信息
执行 ifconfig 或ip addr或ip a命令,都可以显示当前主机中已启用(活动)的网络接口信息 。、
2) 查看指定网络接口信息
格式linux网络追踪的命令:ifconfig 网络接口名
可以通过TX、RX等信息linux网络追踪的命令了解到通过该网络接口发送和接收的数据包个数 , 流量等跟多属性 。
2.hostname命令
在Linux系统中,相当一部分网络服务都会通过主机名来识别本机,如果主机名配置不当,可能会导致程序功能出现故障 。
1) 查看主机名
使用hostname命令就可以查看当前主机的主机名,不添加任何选项参数 。
2) 临时更改主机名
hostname NewName
注:这种方法只是临时的更改主机名 , 重启后将失效 。
3) 永久更改主机名
a. 修改配置文件
RHEL6和7的配置文件存放路径不相同 , 修改配置文件中的主机名,重启就可永久更改主机名 。
RHEL6主机名配置文件路径为:/etc/sysconfig/network
RHEL7主机名配置文件路径为:/etc/hostname
示例
b. 使用命令修改(这种方法只适用于RHEL7或者CentOS7之后)
命令格式:
使用该命令更改后,更改后的主机名就自动写入linux网络追踪的命令了配置文件中,所以可以永久更改主机名,其实就是修改了配置文件 。
3.route命令
直接执行route命令可以查看当前主机中的路由表信息,若结合“-n”选项使用,可以将路由记录中的地址显示为数字形式,这可以跳过解析主机名的过程,在路由表条目较多的情况下能够加快执行速度 。
Destination列对应的是目标网段的地址,Gateway列对应的是吓一跳路由器的地址,Iface列对应的是发送数据的网络接口 。当目标网段为“default”是,表示此行是默认网关记录,当吓一跳为“*”是,表示目标网段是与本机直接相连的 。
4.netstat命令——查看系统的网络连接状态等
netstat命令是了解网络状态及排除网络服务故障的有效工具 。
常用选项:
-a:显示所有活动连接(包括监听、非监听状态的服务端口)
-n:以数字形式显示
-p:显示相关的进程信息
-t:查看 TCP 协议相关信息
-u:查看UDP协议相关信息
-r:显示路由表信息
-l:显示处于监听(listening)状态的网络连接及端口信息
通常使用“-anput”组合选项,结合管道使用“grep”命令 , 来查看一些服务的端口是否开启 。
示例:
Tcp21为ftp服务的端口
二、测试网络连接
1.ping命令——测试网络连通性
常用选项:
-c完成次数:设置完成要求回应的次数
-i间隔秒数:指定收发信息的间隔时间
-q:不显示指令执行过程,开头和结尾的相关信息除外
-s数据包大?。荷柚檬莅拇笮?
-t存活数值:设置存活数值TTL的大小
-v:详细显示指令的执行过程
若返回“Destination Host Unreachable”的反馈信息,则表示目标主机不可达,可能目标地址不存在或主机已关闭linux网络追踪的命令;返回“Network is unreachable”的反馈信息 , 则表示没有可用的路由记录(如默认网关) , 无法到达目标主机所在的网络linux网络追踪的命令;返回“Request timeout”的反馈信息 , 表示与目标主机间的连接超时(数据包缓慢或丢失),若有严格的防火墙限制,也可能返回此信息 。
2.traceroute命令——跟踪数据包的路由途径
使用traceroute命令可以测试从当前主机到目的主机之间经过的网络节点,并显示各中间结点的连接状态(响应时间) 。对于无法响应的节点,连接状态将显示为“*” 。
示例:traceroute IP_ADDR
在网络测试与排错的过程中,通常会先使用ping命令测试与主机的网络连接,如果发现网络有故障,再使用traceroute命令跟踪查看是在哪个中间结点存在故障 。
3.nslookup命令——测试DNS域名解析
nslookup是用来测试(DNS)域名解析的专用工具 。(DNS服务后面再详细讲解,通俗的说就是将域名解析为ip地址的一个服务)
示例:nslookup
若成功反馈要查询域名的IP地址,则表示域名解析没有问题;若出现“...... no servers could be reached”的信息,表示不能连接到指定的DNS服务器;若出现“...... cant’t find xxx.yyy.zzz:NXDOMAIN”的信息 , 表示要查询的域名不存在 。
三、设置网络地址参数
设置网络参数的方法:
? 临时配置 —— 使用命令调整网络参数简单、快速 , 可直接修改运行中的网络参数
一般只适合在调试网络的过程中使用
系统重启以后,所做的修改将会失效
? 永久配置 —— 通过配置文件修改网络参数修改各项网络参数的配置文件
适合对服务器设置固定参数时使用
需要重载网络服务或者重启以后才会生效
1.临时配置——使用网络配置命令(注:RHEL6中网络接口的名称为eth,RHEL7中为ens)
1)使用ifconfig命令修改网卡的地址、状态
ifconfig命令不仅可以用于查看网卡配置,还可以修改网卡的ip地址,子网掩码 , 也可以绑定网络接口、激活或停用网络接口
a. 修改网卡的ip地址(临时修改)
命令格式:
示例:
b. 禁用或者重新激活网卡
命令格式:
示例:
c. 设置虚拟网络接口(相当于一块网卡配置多个IP地址)
命令格式:
示例:
可以根据需要添加更多的虚拟接口 , 如“eth0:1”“eth0:2”等
2)使用route命令添加、删除静态路由记录
? 删除路由表中的默认网关记录命令格式:route del default gw IP地址
? 向路由表中添加默认网关记录命令格式:route add default gw IP地址
? 添加到指定网段的路由记录命令格式:route add -net 网段地址 gw IP地址
? 删除到指定网段的路由记录命令格式:router del -net 网段地址
2.永久配置——修改网络配置文件
1)网络接口配置文件
网络接口的配置文件默认位于目录“/etc/sysconfig/network-scripts/”中 , 文件名格式为:“ifcfg-XXX”,其中“XXX”是网络接口的名称 。例如:RHEL6中网卡eth0的配置文件是“ifcfg-eth0”,而RHEL7中网卡ens33的配置文件是“ifcfg-ens33” 。
在网卡的配置文件中 , 可以看到静态IP地址的部分内容如下图所示:
上述个配置项的含义及作用:(图示为RHEL6中的配置文件,7中也差不多,换汤不换药,修改的都差不多)
? DEVICE:设置网络接口的名称ONBOOT:设置网络接口是否在Linux系统启动时激活BOOTPROTO:设置网络接口的配置方式 , 值为static时表示使用静态ip地址,为dhcp时表示通过dhcp的方式动态获取ip地址IPADDR:设置网络接口的ip地址NETMASK:设置网络接口的子网掩码GATEWAY:设置网络接口的默认网关地址2)重启 network 网络服务
当修改了网络接口的配置文件以后,若要使新的配置生效 , 可以重启network服务或者重启主机或者禁用、启用网络接口 。
示例:
? RHEL6中重启network服务:service network restartRHEL7中重启network服务:systemctl restart network注:这是我在做实验时候的一个经验:RHEL6修改完网卡配置重启后,ip地址仍然没有改过来,这时候我们经常会删除“/etc/udev/rules.d/70-persistent-net.rules”这个文件 。RHEL7不用管 , RHEL7特别好改,RHEL6改的时候特别难受 。(个人提示 , 不求认同)
3)域名解析配置文件
a.指定为本机提供DNS解析的服务器地址
/etc/resolv.conf文件中记录了本机默认使用的DNS服务器的地址信息,对该文件所做的修改将会立刻生效 。Linux系统中最多可以指定3个(第3个以后将被忽略)不同的DNS服务器地址,优先使用第1个DNS服务器 。
示例:
其中“search localdomain”用来设置默认的搜索域(域名后缀) 。例如 , 当访问主机“localhost”时,就相当于访问“localhost.localdomain” 。
b.本地主机映射文件
/etc/hosts文件中记录着一份主机名与ip地址的映射关系表,一般用来保存经常访问的主机信息 。当访问一个未知的域名时,先查找该文件中是否有相应的映射记录,如果找不到在去向DNS服务器查询 。
hosts 文件和 DNS 服务器的比较
? 默认情况下,系统首先从 hosts 文件查找解析记录hosts 文件只对当前的主机有效hosts 文件可减少 DNS 查询过程,从而加快访问速度
路由跟踪命令traceroute / tracert通过traceroute我们可以知道信息从你的计算机到互联网另一端的主机是走的什么路径 。
当然每次数据包由某一同样的出发点(source)到达某一同样的目的地(destination)走的路径可能会不一样linux网络追踪的命令,
但基本上来说大部分时候所走的路由是相同的 。
linux系统中linux网络追踪的命令,我们称之为traceroute,在MS Windows中为tracert 。
traceroute通过发送小的数据包到目的设备直到其返回linux网络追踪的命令,来测量其需要多长时间 。
一条路径上的每个设备traceroute要测3次 。输出结果中包括每次测试的时间(ms)和设备的名称(如有的话)及其IP地址 。
说明:
记录按序列号从1开始 , 每个纪录就是一跳,每跳表示一个网关,我们看到每行有三个时间,单位是ms,其实就是-q的默认参数 。
探测数据包向每个网关发送三个数据包后,网关响应后返回的时间;如果您用 traceroute -q 4,表示向每个网关发送4个数据包 。
有时我们traceroute 一台主机时,会看到有一些行是以星号表示的 。
出现这样的情况,可能是防火墙封掉了ICMP的返回信息,所以我们得不到什么相关的数据包返回数据 。
有时我们在某一网关处延时比较长,有可能是某台网关比较阻塞,也可能是物理设备本身的原因 。
当然如果某台DNS出现问题时,不能解析主机名、域名时,也会 有延时长的现象;
您可以加-n 参数来避免DNS解析,以IP格式输出数据 。
如果在局域网中的不同网段之间,我们可以通过traceroute 来排查问题所在,是主机的问题还是网关的问题 。
如果我们通过远程来访问某台服务器遇到问题时,我们用到traceroute 追踪数据包所经过的网关,提交IDC服务商,也有助于解决问题;
但目前看来在国内解决这样的问题是比较困难的,就是我们发现问题所在,IDC服务商也不可能帮助我们解决 。
说明:
Traceroute的工作原理:
Traceroute最简单的基本用法是:traceroute hostname
Traceroute程序的设计是利用ICMP及IP header的TTL(Time To Live)栏位(field) 。
首先,traceroute送出一个TTL是1的IP datagram
(其实,每次送出的为3个40字节的包,包括源地址,目的地址和包发出的时间标签)到目的地,
当路径上的第一个路由器(router)收到这个datagram时,它将TTL减1 。此时,TTL变为0了,
所以该路由器会将此datagram丢掉,并送回一个「ICMP time exceeded」消息
(包括发IP包的源地址 , IP包的所有内容及路由器的IP地址),traceroute 收到这个消息后,
便知道这个路由器存在于这个路径上 , 接着traceroute 再送出另一个TTL是2 的datagram,
发现第2 个路由器...... traceroute 每次将送出的datagram的TTL 加1来发现另一个路由器,
这个重复的动作一直持续到某个datagram 抵达目的地 。当datagram到达目的地后 ,
该主机并不会送回ICMP time exceeded消息,因为它已是目的地了,那么traceroute如何得知目的地到达了呢linux网络追踪的命令?
Traceroute在送出UDP datagrams到目的地时,它所选择送达的port number 是一个一般应用程序都不会用的号码(30000 以上),
所以当此UDP datagram 到达目的地后该主机会送回一个「ICMP port unreachable」的消息,
而当traceroute 收到这个消息时,便知道目的地已经到达了 。所以traceroute 在Server端也是没有所谓的Daemon 程式 。
Traceroute提取发 ICMP TTL到期消息设备的IP地址并作域名解析 。
每次 ,Traceroute都打印出一系列数据,包括所经过的路由设备的域名及 IP地址,三个包每次来回所花时间 。
【linux网络追踪的命令 linux中追踪路由】linux网络追踪的命令的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux中追踪路由、linux网络追踪的命令的信息别忘了在本站进行查找喔 。

    推荐阅读