Traceroute(路由追踪)
Traceroute的实现有两种:
基于UDP实现
traceroute向目的主机发送一系列普通IP数据报,但每个数据报携带一个不可达UDP端口号的UDP报文,TTL分别为1,2,3...TTL过期时,路由器丢弃数据报并发送ICMP告警报文给源主机。如何得知何时停止发送UDP报文?目的主机会发送端口不可达的ICMP报文,中间路由器则发送ICMP超时报文。
基于ICMP实现
直接发送一个ICMP回显请求(echo request)数据包,服务器在收到回显请求的时候会向客户端发送一个ICMP回显应答(echo reply)数据包,在这之后的流程还是跟第一种方案一样。这样就避免了我们的traceroute数据包被服务器的防火墙策略墙掉。
In Unix/Linux, the source sends a series of UDP packets to the target destination using an unlikely destination port number;
in Windows, the source sends a series of ICMP packets to the target destination.
For both operating systems, the program sends the first packet with TTL=1, the second packet with TTL=2, and so on.
在Windows系统中也有traceroute程序,它的名字叫做tracert,tracert就是用基于这种方法采用ping来实现的。
相关实现代码见以下参考链接
附:
ICMP与IP同属于网络层,但同TCP, UDP类似,被IP封装。
ICMP虽然被IP封装,但不代表ICMP属于传输层。
网络层的层次并不是通过A封装了B,A就在B的下一层来区分的。
Traceroute(路由追踪)的更多相关文章
- 10.10 traceroute:追踪数据传输路由状况
		traceroute命令 用于显示网络数据包传输到指定主机的路径信息,追踪数据传输路由状况.默认数据包大小是60字节(IPv4)或80字节(IPv6),用户可另行设置.它与Windows下的trace ... 
- 路由追踪:traceroute/tcptraceroute
		一.工作原理 traceroute:IP路由过程中对数据包TTL(Time to Live,存活时间)进行处理.当路由器收到一个IP包时,会修改IP包的TTL(及由此造成的头部检验和checksum变 ... 
- Traceroute(路由追踪)的原理及实现
		现实世界中的网络是由无数的计算机和路由器组成的一张的大网,应用的数据包在发送到服务器之前都要经过层层的路由转发.而Traceroute是一种常规的网络分析工具,用来定位到目标主机之间的所有路由器 原理 ... 
- tracteroute路由追踪
		traceroute 跟踪数据包到达网络主机所经过的路由工具: 是用来发出数据包的主机到目标主机之间所经过的网关的工具.traceroute 的原理是试图以最小的TTL发出探测包来跟踪数据包到达目标主 ... 
- [Linux] traceroute 路由跟踪指令用例
		traceroute是用来跟踪数据包到达网络主机所经过的路由工具.在Linux系统中,称之为traceroute,在Windows中称为tracert. 一条路径上的每个设备traceroute要测3 ... 
- Delphi用Socket API实现路由追踪
		Windows自带的Tracert是向远程主机发送ICMP包进行追踪,但是目前很多主机关闭了ICMP答复,这个工具不太好使了~~~~~原理咱知道,正规的Trace不就是发送TTL依次递增的UDP包吗? ... 
- Python—路由追踪(并生成追踪图片)
		需要先安装两个包 [root@localhost ~]# yum install graphviz // 为了使用dot命令 [root@localhost ~]# yum install Image ... 
- 边缘节点  如何判断CDN的预热任务是否执行完成刷新 路由追踪  近期最少使用算法
		阿里云内容分发网络(Content Delivery Network,简称CDN)是建立并覆盖在承载网之上,由分布在不同区域的边缘节点服务器群组成的分布式网络.阿里云CDN分担源站压力,避免网络拥塞, ... 
- python利用scapy模块写一个TCP路由追踪和扫描存活IP的脚本
		前言: 没有前言 0x01 from scapy.all import * import sys from socket import * import os from threading impor ... 
随机推荐
- jqgrid editrules参数说明
			转载至:jqgrid的editrules参数 以下为内容留存记录. editrules editrules是用来设置一些可用于可编辑列的colModel的额外属性的.大多数的时候是用来在提交到服 ... 
- Junit测试中找不到junit.framework.testcase
			在使用Junit进行测试时,出现如下问题: 找不到junit.framework.testcase 解决方法: 选中项目->属性->Java构建路径->库->添加外部jar 在 ... 
- PHP和PHPINFO
			PHP开放源码和跨越平台,PHP可以运行在WINDOWS和多种版本的LINUX上.它不需要任何预先处理而快速反馈结果,它也不需要mod_perl的调整来使您的服务器的内存映象减小.PHP消耗的资源较少 ... 
- 2017-2018-4 20155317《网络对抗技术》EXP3 免杀原理与实践
			2017-2018-4 20155317<网络对抗技术>EXP3 免杀原理与实践 一.问题回答 (1)杀软是如何检测出恶意代码的?杀软是通过代码特征比对得出的,将检查的代码和自己的特征库的 ... 
- IHttpModule不起作用的两个原因
			最近在将系统改造成微服务的过程中,需要对以前的Url请求做兼容性处理,于是就采用了HttpModules模型,但在测试中碰到IHttpModules模块不起作用. 一.IIS配置问题 我用的IIS7. ... 
- C语言和python的区别
			Python可以说是目前最火的语言之一了,人工智能的兴起让Python一夜之间变得家喻户晓,Python号称目前最最简单易学的语言,现在有不少高校开始将Python作为大一新生的入门语言.本萌新也刚开 ... 
- python高并发和多线程的关系
			“高并发和多线程”总是被一起提起,给人感觉两者好像相等,实则 高并发 ≠ 多线程 多线程是完成任务的一种方法,高并发是系统运行的一种状态,通过多线程有助于系统承受高并发状态的实现. 高并发是一种系 ... 
- 阿里云 ECS 监控报警设置
			1.阿里云监控项说明 https://helpcdn.aliyun.com/document_detail/43505.html 2.监控设置 3.报警规则 4.设置阈值 5.确定即可. 6.效果图 
- 关于ueditor一些使用记录
			1.使用的引用配置顺序 <script src="utf8-net/ueditor.config.js"></script> <script src= ... 
- shellcode 编码技术
			在很多漏洞利用场景中, shellcode 的内容将会受到限制. 例如你不能输入 \x00 这个字符,编辑框不能输入 \x0d \x0a这样的字符 所以需要完成 shellcode 的逻辑,然后使用编 ... 
