如何使用Linux探测路由? (linux 探测路由)

在计算机网络领域中,路由是一个十分重要的概念。路由器是连接多个网络的设备,通过它可以实现数据的传输和路由选择。为了确保网络顺畅运行,必须对路由器进行有效的管理和探测。在本文中,我们将介绍如何使用Linux探测路由。

一、通过ping命令探测路由

Ping命令是最常用的检测网络连接问题的工具之一。它也可以用来检测网络路由表,主要用来检测链路层、网络层和传输层是否可达。以下是使用ping命令进行路由探测的步骤:

1. 打开终端。

2. 输入ping命令并指定路由器IP地址,例如ping 192.168.1.1。

3. 按下回车键,等待数秒钟。

如果路由器可达,它将回复一个“响应”消息,否则将显示超时错误或其他错误。这个方法很简单,但是要注意一些问题,如网络拥塞和防火墙设置可能会导致探测失败。

二、通过traceroute命令探测路由

Traceroute命令是一种用来确定数据包从源到目的地址经过的路由器的工具。它通过向目标地址发送一系列的ICMP数据包来追踪路径。以下是使用traceroute命令进行路由探测的步骤:

1. 打开终端。

2. 输入traceroute命令并指定目标IP地址,例如traceroute 192.168.1.1。

3. 按下回车键,等待输出结果。

结果将显示到达目标地址所经过的每个路由器的IP地址、每个路由器的响应时间和TTL(Time To Live)值。TTL值是每个数据包在到达目的地之前可以通过的更大路由数目。

三、通过tcptraceroute命令探测路由

Tcptraceroute命令是对traceroute的一种改进,它使用TCP协议而不是UDP协议来发送数据包,并采用标准TCP连接的方式与每个路由器建立连接,这样可以更好地跟踪由于防火墙问题而导致的问题。以下是使用tcptraceroute命令进行路由探测的步骤:

1. 打开终端。

2. 输入tcptraceroute命令并指定目标IP地址,例如tcptraceroute 192.168.1.1。

3. 按下回车键,等待输出结果。

结果将显示到达目标地址所经过的每个路由器的IP地址、每个路由器的响应时间和TTL值。与traceroute命令相比,tcptraceroute命令具有更好的跟踪效果和更精确的错误报告。

四、通过mtr命令探测路由

Mtr命令是一个跨平台的网络诊断工具,它将ping和traceroute两种工具结合在一起,可以提供更全面的网络诊断和路由探测功能。以下是使用mtr命令进行路由探测的步骤:

1. 打开终端。

2. 输入mtr命令并指定目标IP地址,例如mtr 192.168.1.1。

3. 按下回车键,等待输出结果。

结果将显示到达目标地址所经过的每个路由器的IP地址、每个路由器的响应时间、TTL值和丢失的数据包数量。Mtr命令还提供了实时的网络性能数据和一系列跟踪图表,可以更直观地展示网络状况和路由问题。

路由是计算机网络中的一个重要概念,必须时刻保持清晰和有效。Linux操作系统提供了多种方式来探测路由器,如ping、traceroute、tcptraceroute和mtr命令。根据不同的网络情况和需求,选择适合的工具可以更加准确地发现和解决网络问题,从而保证网络的高效性和稳定性。

相关问题拓展阅读:

如何理解ip路由和操作linux的路由表

路由其实就是选择一条数据包传输路径的过程,也就是说主机怎么向它的目滑搏的地顺利发送数据的过程。当TCP/IP主机发送IP数据包时,便出现了路由,且当到达IP路由器时还会再次出现。路由器是从一个物理网向另一个物理网发送数据包的装置,路由器通常被称为网关,它承但着分发数据包的任务。对于发送的主机和路由器而言,必须决定向哪里转发数据包。在决定路由时,IP层查询位于内存中的路由表,然后根据查询规则,进行ip路由。是不是很宴让袜抽象?用我的话说吧,也就是下面要讨论的问题。

  先说如何选路:

(1)当一个主机试图与另一个主机通信时,IP首先决定目的主机是一个内网还是外网,怎么确定?当然使用网络号。

(2)如果是是同一内网,那就就是直接发送了,这个最简答不过了。

(3)如果目的主机是和发送主机不在同一个内网,也就是在外网了,^_^很啰嗦,IP将查询路由表来为外网主机或外网选择一个路由,所以一般情况下有可能为某个外网指定特定的路由,具体问题稍后分析。

(4)若未找到明确的路由,此时在路由表中还会有默认网关,也可称为缺省网关,IP用缺省的网关地址将一个数据传送给下一个指定的路由器,所以网关也可能是路由器,也可能只是内网向特定路由器传输数据的网关。

(4)在该路由器收到数据后,它再次为远程主机或网络查询路由,若还未找到路由,该数据包将发送到该路由器的缺省网关地址。

  每发现一条路由,数据包被转送下一级路由器,称为一次“跳步”,按照同样的方式进行转发,并最终发送至目的主机。若未发现任何一个路由可以接受此次ip包的地址,发送主机将收到一个出错信息,也就是说其中任何一跳出现了不可到达,最后的结果也就是报错了。

  上面只是个人的一些理解,事实上当时我们做的实验不少,但是看看tcp/ip详解后,就可以一目了然了,现在以linux下的路由表为例说明一下:

$ sudo route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

.168.100.0 * 255.255.255.0 Ueth1

.168.10.0 * 255.255.254.0 Ueth0

default 192.168.10.1 0.0.0.0 UGeth0

——

  IP路由选择是逐跳地(hop-by-hop)进行的。从这个路由表信息可以看出,IP并不知道到达任何目的的完整路径(当然,除了那些与主机直接相连的目的)。所有的IP路由选择只为数据报传输提供下一站路由器的IP地址。它假定下一站路由器比发送数据报的主机更接近目的,而且下一站路由器与该主机是直接相连的。

IP路由选择主要完成以下这些功能:

1)搜索路由表,寻找能与目的IP地址完全匹配的表目(网络号和主机号都要匹配)。如果找到,则把报文发送给该表目指定的下一站路由器或直接连接的网络接口(取决于标志字段的值)。

2) 搜索路由表,寻找能与目的网络号相匹配的表目。如果找到,则把报文发送给该表目指定的下一站路由器或直接连接的网络接口(取决于标志字段的值)。目的网络上的所有主机都可以通过这个表目来处置。例如,一个以太网上的所有主机都是通过这种表目进行寻径的。这种搜索网络的匹配方法必须考虑可能的子网掩码。关于这一点我们在下一节中进行讨论。

3)搜索路由表,寻找标为“默认(default)”的表目。如果找到,则把报文发送给该表目指定的下一晌激站路由器。如果上面这些步骤都没有成功,那么该数据报就不能被传送。如果不能传送的数据报来自本机,那么一般会向生成数据报的应用程序返回一个“主机不可达”或 “网络不可达”的错误。

完整主机地址匹配在网络号匹配之前执行。只有当它们都失败后才选择默认路由。默认路由,以及下一站路由器发送的ICMP间接报文(如果我们为数据报选择了错误的默认路由),是IP路由选择机制中功能强大的特性。

  以上的解释都很清楚了,不用再详细解释怎么走了,如果你实在还不能理解的话,去看tcp/ip详解吧。顺便解释一下上面的output内容:

The output of the kernel routing table is organized in the following columns

Destination

The destination network or destination host.

Gateway

The gateway address or ‘*’ if none set.

Genmask

The netmask for the destination net; ‘255.255.255.255’ for a host destination and ‘0.0.0.0’ for the default route.

Flags Possible flags include

U (route is up)

H (target is a host)

G (use gateway)

R (reinstate route for dynamic routing)

D (dynamically installed by daemon or redirect)

M (modified from routing daemon or redirect)

A (installed by addrconf)

C (cache entry)

! (reject route)

Metric The ‘distance’ to the target (usually counted in hops). It is not used by recent kernels, but may be needed by

routing daemons.

Ref Number of references to this route. (Not used in the Linux kernel.)

Use Count of lookups for the route. Depending on the use of -F and -C this will be either route cache misses (-F) or

hits (-C).

Iface Interface to which packets for this route will be sent.

MSS Default maximum segment size for TCP connections over this route.

Window Default window size for TCP connections over this route.

irtt Initial RTT (Round Trip Time). The kernel uses this to guess about the best TCP protocol parameters without wait-

ing on (possibly slow) answers.

HH (cached only)

The number of ARP entries and cached routes that refer to the hardware header cache for the cached route. This

will be -1 if a hardware address is not needed for the interface of the cached route (e.g. lo).

Arp (cached only)

Whether or not the hardware address for the cached route is up to date

  同时在freebsd上使用netstat -nr打印路由表,也顺便提示一下。

  现在问题在如何操作路由表,因为ip的选路全靠它吃饭了,怎么为一个特定的网络或者主机选择一条特定的路由?如何删除路由?这些问题对于网络维护和系统管理也尤为重要:

  还是以上面的路由表为例,建议使用前先man route查看方法,或许各个系统略有差异,下面是以debian为例,由于是测试,所以使用sudo,而不是root权限:

  1、为某主机添加路由

$ sudo route add –host 192.168.10.58 dev eth1

//所有通向192.168.10.58的数据都是用eth1网卡

$ sudo route add –host 192.168.11.58 gw 192.168.10.1

//通向192.168.11.58的数据使用网关192.168.10.1

  不经意间做了一个验证实验:由于eth1是没有启动的,所以添加这个路由后,192.168.10.58不可ping通

初始路由表

sudo route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

.168.100.0 * 255.255.255.0 Ueth1

.168.10.0 * 255.255.254.0 Ueth0

default 192.168.10.1 0.0.0.0 UGeth0

  可以ping通192.168.10.58

$ ping 192.168.10.58

PING 192.168.10.58 (192.168.10.58) 56(84) bytes of data.

bytes from 192.168.10.58: icmp_seq=1 ttl=64 time=0.188 ms

  添加192.168.10.58的路由

$ sudo route add -host 192.168.10.58 dev eth1

$ sudo route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

.168.10.58 * 255.255.255.255 UHeth1

.168.100.0 * 255.255.255.0 Ueth1

.168.10.0 * 255.255.254.0 Ueth0

default 192.168.10.1 0.0.0.0 UGeth0

  由于eth0无法使用了,所以发给eth1,就等于丢入黑洞之中

$ ping 192.168.10.58

PING 192.168.10.58 (192.168.10.58) 56(84) bytes of data.

.168.10.58 ping statistics —

2 packets tranitted, 0 received, 100% packet loss, time 1010ms

  指定给网关处理

$ sudo route add -host 192.168.10.58 gw 192.168.10.1

$ sudo route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

.168.10.58 192.168.10.1 255.255.255.255 UGHeth0

.168.10.58 * 255.255.255.255 UHeth1

.168.100.0 * 255.255.255.0 Ueth1

.168.10.0 * 255.255.254.0 Ueth0

default 192.168.10.1 0.0.0.0 UGeth0

  要经过网关了,验证了路由表的作用

$ ping 192.168.10.58

PING 192.168.10.58 (192.168.10.58) 56(84) bytes of data.

From 192.168.10.1: icmp_seq=1 Redirect Network(New nexthop: 192.168.10.58)

bytes from 192.168.10.58: icmp_seq=1 ttl=64 time=1.02 ms

  废话少说了,同理为某网路添加路由和删除路由如下所示:经过测试有效:

  2、为某网络的添加路由

$ sudo route add –net 220.181.8.0/24 dev eth0

$ sudo route add –net 220.181.8.0/24 gw 192.168.10.1

  3、添加默认网关

$ sudo route add default gw 192.168.10.1

4、删除路由,

$ sudo route del –host 192.168.168.110 dev eth0

  可能你会遇到删除时候语法错误,请参看路由表的Flags,路由上面的之一条,G表示设定了网关,H表示操作了主机,所以就用$ sudo route del -host 192.168.10.58 gw 192.168.10.1删除,更详细的请man。

  使用route 命令添加的路由,机器重启或者网卡重启后路由就失效了,和iptables一样,需要永久添加的话,也是使用开机执行,所以可以用以下方法添加永久路由:

  1.在/etc/rc.local里添加执行命令,进行开机执行,因为是root权限,所以不用sudo了:

route add –net 220.181.8.0/24 dev eth0

route add –net 220.181.9.0/24 gw 192.168.10.1

  2.在/etc/sysconfig/network里添加到末尾

方法:GATEWAY=gw-ip 或者 GATEWAY=gw-dev

  3./etc/sysconfig/static-router :

any net x.x.x.x/24 gw y.y.y.y

Linux多网卡与路由

之前在调试Linux多网卡驱动时,想在应用层实现默认网关的自动切换,需要了解路由的知识,特此总结。

路由是指数据包从源节点到目的节点过程中,决定端到端路径的行为。说白了,就是数据在网络中从一个主机到另一个主机的传递路径。举个例子,我上班需要从家(A)走到公交站(B)坐130路车到大公司(C),那么我上班的路由就是A -> B -> C。

可以理解成是保存某个主机的所有路由信息的。还是说上班那个例子,我也可以从家里(A)走到公家站(B)先坐220路车到达山东路公交站(B1),再转106路车到达公司(C),所以A -> B -> B1 -> C也是一条路由信息,那么这两条路由信息都属于我的路由表。

路由器主要负责查询数据在网络中的传递路由信息,并完成数据包的投递。再举个公交车的例子,假如有一天我想去五四广场(D)玩,但不知道坐哪路车,所以我先从家里(A)走到公交站(B),查了一下站牌信息,需要做128路车到达,接着我就等车来然后坐车抵达目的地。在这个情景中,公交站就相当于路核槐由器,帮我查到坐车信息并经此抵达,相应的A -> B -> D就是对应的路由。

以上只是对这几个重要概念的简单理解,真实网宽氏李络环境中肯定要复杂许多。

正常情况下,嵌入式板子有一个网卡就够用了,要慎迟么WiFi,要么以太网。但有时候需要多个网卡的情况,以连接不同的子网。运行ifconfig命令可以查看系统网卡信息:

上面信息表明我的系统中有两个以太网卡,一个网络接口连到 192.168.10.* 段网络,另一个网络接口连到 192.168.56.* 段网络。再来看一下路由表信息,运行route命令可以查看:

上述 route 命令输出信息中各项的含义请看下表:

可以看到路由表里有4条路由信息。如果要发送的数据包的目的地址是192.168.56.8,跟之一条路由信息的子网掩码做与运算得到192.168.56.0,可判断与路由信息中目的网络地址不符;再跟第二条路由信息的子网掩码做与运算得到192.168.56.0,正是第二行的目的网络地址,因此数据从eth1网卡发送出去,由于192.168.56.0正是与eth1接口直接相连的网络,因此可以直接发到目的主机,不需要经路由器转发。如果要发送的数据包的目的地址是114.114.114.114,跟前三条路由表条目都不匹配,那么就要按缺省路由信息,从eth0网卡发出去,首先发往地址为192.168.10.1的路由器,再让路由器根据它的路由表决定下一跳地址。

通过上面的分析可以发现,若使网络中任意两个节点能够通信,要么在路由表有对应的路由信息,要么通过默认网关进行转发。

纯个人理解,如有问题,欢迎指正~~~

如何使用linux服务器实现路由器的功能

1.开启内核的路由转发功租烂能岁档a

修改/etc/sysctl.conf文件,在里面弊雀漏添加一行 net.ipv4.ip_forward=0

2.sysctl -p #识别修改的的文件

3.添加路由表

route add -net 0.0.0.0/24 gw 7.7.7.2

linux 探测路由的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux 探测路由,如何使用Linux探测路由?,如何理解ip路由和操作linux的路由表,Linux多网卡与路由,如何使用linux服务器实现路由器的功能的信息别忘了在本站进行查找喔。


数据运维技术 » 如何使用Linux探测路由? (linux 探测路由)