一、tracert和traceroute简介

  1. 相同点:都是用来跟踪路由,帮助排查问题,关注的是过程,而ping关注的是结果
  2.  
  3. 不同点:tracert请求是icmp echo报文
  4.  
  5.     traceroute请求是UDP的报文,目标端口是30000以上随机端口

二、tracert使用到三种报文

  1. icmp echo request #icmp Type0,客户端发起报文,traceroute使用udp报文发起
  2. icmp echo replay #icmp Type 8到了目标地址,未禁ping,回复此报文
  3. icmp time-exceeded #icmp Type11,经过的路由回复报文(到此路由ttl=1或0回复给客户端)

三、traceroute使用的三种报文

  1. UDP随机端口发起请求 #icmp Type0,客户端发起报文,traceroute使用udp报文发起
  2. icmp time-exceeded #icmp Type11,经过的路由回复报文(到此路由ttl=1或0回复给客户端)
  3. icmp unreachable #icmp Type3(Destination unreachable),到了目标地址,未禁ping,回复此报文

四、tracert原理

  1. 1.tracert送出一个TTL1ICMP echo request数据包a到目的地
  2. 2.当路径上的第一个路由器收到这个数据包a时,它将TTL1
  3. 3.TTL变为0,该路由器会将此数据包丢掉,并送回一个「ICMP time exceeded」消息
  4. 4.tracert 收到这个消息后,再送出另一个TTL2 的数据包,发现第2 个路由器
  5. 5.当数据包到达目的地后,目标会送回一个icmp echo reply(前提是目标未禁ping)

ps:tracert 有一个固定的时间等待响应(ICMP TTL到期消息)。如果这个时间过了,它将打印出一系列的*号,表明在这个路径上,这个设备不能在给定的时间内发出ICMP TTL到期消息的响应。

有些时候tracert都是打星号,但是抓包显示icmp time-exceeded(即可知所经路由器),所以以抓包结果为准

五、tracert工具使用

  用法:

  tracert [-d] [-h maximum_hops] [-j host-list] [-w timeout] [-R] [-S srcaddr] [-4] [-6] target_name

  1. -d #不将地址解析成主机名。
  2. -h maximum_hops #设置目标的最大跃点数。
  3. -j host-list #与主机列表一起的松散源路由(仅适用于 IPv4)。
  4. -w timeout #等待每个回复的超时时间(以毫秒为单位)。
  5. -R #跟踪往返行程路径(仅适用于 IPv6)。
  6. -S srcaddr #要使用的源地址(仅适用于 IPv6)。
  7. -4 #强制使用 IPv4。
  8. -6 #强制使用 IPv6。

六、traceroute工具参数使用

  用法:

  traceroute [ -46dFITnreAUDV ] [ -f first_ttl ] [ -g gate,... ] [ -i device ] [ -m max_ttl ] [ -N squeries ] [ -p port ] [ -t tos ] [ -l flow_label ] [ -w waittime ] [ -q nqueries ] [ -s src_addr ] [ -z sendwait ] [ --fwmark=num ] host [ packetlen ]

  1. -d #使用Socket层级的排错功能。
  2.  
  3. -f first_ttl #设置第一个检测数据包的存活数值TTL的大小。
  4.  
  5. -F #设置勿离断位。
  6.  
  7. -g gate,... #设置来源路由网关,最多可设置8个。
  8.  
  9. -i device #使用指定的网络接口送出数据包。
  10.  
  11. -I #使用ICMP echo request取代UDP请求,即类似使用tracert工具
  12.  
  13. -T #使用TCP SYN取代UDP请求
  14.  
  15. -m max_ttl #设置检测数据包的最大存活数值TTL的大小。
  16.  
  17. -n #直接使用IP地址而非主机名称。
  18.  
  19. -p port #设置UDP传输协议的通信端口,默认33434
  20.  
  21. -r #忽略普通的Routing Table,直接将数据包送到远端主机上。
  22.  
  23. -s src_addr #设置本地主机送出数据包的IP地址。
  24.  
  25. -t tos #设置检测数据包的TOS数值。
  26.  
  27. -w waittime #设置等待远端主机回应的时间,默认5s

七、示例演示

  7.1 禁止设备被tracert,希望对方tracert时打星号

  以一台思科3850为例,根据上面tracert原理,跟踪到路径的地址是根据回复icmp time-exceeded的源地址得到,因此只要禁止指定的icmp time-exceeded的报文即可达到设备禁止tracert的效果

  1. 路径图:PC1-->G2/0/16_A_G2/0/17-->G2/0/16_B_G2/0/17-->G2/0/16_C_G2/0/17-->目标server
  2. 假设A设备为CISCO 3850纯当二层设备使用,B设备地址192.168.6.1
  3. (A)#ip access-lists extent test
  4. 10 deny icmp host 192.168.6.1 host 192.168.60.244 ttl-exceeded
  5. 20 permit ip any any
  6. QJ-W-3850-2F#
  7. interface GigabitEthernet2/0/16
  8. switchport access vlan 60
  9. switchport mode access
  10. ip access-group test out
  11.  
  12. #注意:二层设备也可以应用acl过滤三层地址

tracert和traceroute介绍的更多相关文章

  1. 同一个目标ip在windows下使用tracert正常但是在linux下使用traceroute中间节点不显示?tracert与traceroute原理与抓包分析

    针对第一个问题先说结论 windows的tracert是使用icmp来探路,linux的traceroute是使用udp探测,如果想达到和windows下一个效果,建议使用-I参数或mtr 下面是原理 ...

  2. tracert和traceroute使用

    Traceroute提取发 ICMP TTL到期消息设备的IP地址并作域名解析.每次 ,Traceroute都打印出一系列数据,包括所经过的路由设备的域名及 IP地址,三个包每次来回所花时间. 转自 ...

  3. Linux命令:traceroute(windows中为tracert)

    通过traceroute 我们可以知道信息从你的计算机到互联网另一端的主机是走的什么路径.当然每次数据包由某一同样的出发点(source)到达某一同样的目的地(destination)走的路径可能会不 ...

  4. [svc]traceroute(udp+icmp)&tracert(icmp)原理

    2018年4月11日 11:41:29更新 工具 发包 触发点 结局 traceroute 初始发udp包 ttl递增,icmp每一跳报ttl超时 udp端口不可达 tracert 初始发icmp r ...

  5. 通过route , tracert , traceroute 查看本地路由配置及访问ip或域名时经过的路由信息

    转载请注明出处: 1.路由器和交换机的区别和过程 在windows 系统或linux 系统访问 外网ip 或域名时,都会通过层层的路由器,然后将请求转发到最终的目标服务器:因为互联网通过路由器实现公网 ...

  6. traceroute命令详解

    基础命令学习目录首页 原文链接:https://www.cnblogs.com/peida/archive/2013/03/07/2947326.html 通过traceroute我们可以知道信息从你 ...

  7. 网络路径查询traceroute

    Traceroute用法   网友:适兕 发布于: 2006.08.24 08:14 (共有条评论) 查看评论 | 我要评论   一.什么是Traceroute?                 In ...

  8. 每天一个linux命令(55):traceroute命令

    通过traceroute​我们可以知道信息从你的计算机到互联网另一端的主机是走的什么路径.当然每次数据包由某一同样的出发点(source)到达某一同样的目的地(destination)走的路径可能会不 ...

  9. 每天一个linux命令(47):traceroute命令

    通过traceroute我们可以知道信息从你的计算机到互联网另一端的主机是走的什么路径.当然每次数据包由某一同样的出发点(source)到达某一同样的目的地(destination)走的路径可能会不一 ...

随机推荐

  1. [Spring+SpringMVC+Mybatis]框架学习笔记(六):事务

    第7讲 事务 7.1 事务的概念 事务是一系列作为一个逻辑单元来执行的操作集合. 它是数据库维护数据一致性的单位,它讲数据库从一个一致状态,转变为新的另外一个一致状态.说的简单一点就是:如果一组处理步 ...

  2. Excel催化剂开源第19波-一些虽简单但不知道时还是很难受的知识点

    通常许多的知识都是在知与不知之间,不一定非要很深奥,特别是Excel这样的应用工具层面,明明已经摆在那里,你不知道时,永远地不知道,知道了,简单学习下就已经实现出最终的功能效果. 在程序猿世界里,也是 ...

  3. Python学习2——Python单行注释、整段注释使用方法

    Python中的注释有多种,有单行注释,多行注释,批量注释,中文注释也是常用的. python注释也有自己的规范,在文章中会介绍到. 注释可以起到一个备注的作用,团队合作的时候,个人编写的代码经常会被 ...

  4. 找bug的过程

    关于昨天程序出差我找bug的过程记录 昨天才程序 https://www.cnblogs.com/pythonywy/p/11006273.html ├── xxxx │ ├── src.py │ └ ...

  5. Hive调优策略

    Hive调优策略 Fetch抓取 Fetch抓取是指,Hive中对某些情况的查询可以不必使用MapReduce计算. 例如:select * from employee:在这种情况下,Hive可以简单 ...

  6. 不同版本2.5的Servlet web.xml 头信息

    <?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" ...

  7. mysql查看视图用户

    select `DEFINER` from  information_schema.VIEWS;

  8. 使用GDAL实现DEM的地貌晕渲图(三)

    目录 1. 原理 1) ArcMap生成彩色晕渲图 2) 彩色色带赋值 3) 颜色叠加 2. 实现 3. 结语 4. 参考 1. 原理 之前在<使用GDAL实现DEM的地貌晕渲图(一)>和 ...

  9. Angular JS 中的内置方法之$watch

    在$apply方法中存在脏检查,首先apply方法会触发evel方法,当evel方法解析成功后,会去触发digest方法,digest方法会触发watch方法. $watch(watchFn,watc ...

  10. eclipse Mac 下补全代码

    1. 每次输入都自动提示 点击 Eclipse,使其成为第一响应者,preferences->Java->Editor->Content Assist再右下角 Auto activa ...