首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

关于UDP接收icmp端口不可达(port unreachable)

本篇分为3部分 1:报文格式 2:产生的原因 3:linux协议栈如何处理 4:应用层如何获取 1: 报文如下,10.30.13.1往10.30.16.10的80端口发送了一个UDP报文,80端口其实监听的是...服务器回复了一个类型为端口不可达的ICMPICMP数据部分就是请求UDP ip层及其以上的数据。 2:原因 首先原因就是接收udp报文的服务器对应的端口没有开启UDP服务器。...3:Linux内核对UDP处理: (1):作为服务器接受到一个UDP请求: 首先,做为服务器,当一个报文经过查路由,目的ip是上送本机的时候,经过netfilter 判决后, 调用ip_local_deliver_finish...= NULL),就回复icmp destination unreachable(这就是服务器没有对应端口接受UDP的处理流程),函数非常简单 所以作为服务器,收到一个目的端口并未监听的报文,直接回复端口不可达...(2)作为客户端收到ICMP端口不可达的回复: 作为客户端,端口不可达报文进入ip_local_deliver_finish,它调用icmp_rcv函数,进行处理。

9.2K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux编程之ICMP洪水攻击

    我的上一篇文章《Linux编程之PING的实现》里使用ICMP协议实现了PING的程序,ICMP除了实现这么一个PING程序,还有哪些不为人知或者好玩的用途?...这里我将介绍ICMP另一个很有名的黑科技:ICMP洪水攻击。...ICMP洪水攻击属于大名鼎鼎的DOS(Denial of Service)攻击的一种,一种是黑客们喜欢的攻击手段,这里本着加深自己对ICMP的理解的目的,也试着基于ICMP写一段ICMP的洪水攻击小程序...要实现ICMP的洪水攻击,需要以下三项的知识储备: DOS攻击原理 ICMP的深入理解 原始套接字的编程技巧 一、ICMP洪水攻击原理 ICMP洪水攻击是在ping的基础上形成的,但是ping程序很少能造成目的及宕机的问题...= ICMP_ECHO; icmp_hdr->icmp_code = 0; icmp_hdr->icmp_cksum = htons(~(ICMP_ECHO << 8)); //注意这里,

    2.2K21

    ICMP

    ICMP ICMP用来传递差错控制,查询等信息。 ICMP Echo消息常用于诊断源和目的之间的网络连通性,同时还可以提供其他信息,如报文往返时间等。...当网络设备无法保证访问目标网络时,会自动发送ICMP目的不可达报文到发送端设备 type表示ICMP消息类型,code表示同一消息类型中的不同信息。  ICMP的一个典型应用是ping。...用户可以在ping命令中指定不同参数,如ICMP报文长度、发送ICMP报文个数、等待回复响应的超时时间等,设备根据配置的参数来构造并发送ICMP报文,进行ping测试。...如果不指定源IP地址,将采用出接口的IP地址作为ICMP echo-request报文发送的源地址。 2、-c count指定发送ICMP echo-request报文次数。...缺省值是255 4、-t timeout指定发送完ICMP echo-request后,等待ICMP echo-replay的超时时间。 Tracert ICMP的另一个典型应用是Tracert。

    1.2K20

    linux关闭端口进程命令,linux关闭端口命令

    linux中我们可以通过命令来启动和关闭端口,那么具体是哪个命令呢?下面由学习啦小编为大家整理了linux关闭端口的相关命令,希望对大家有所帮助。...linux关闭端口命令 前提:首先你必须知道,端口不是独立存在的,它是依附于进程的。某个进程开启,那么它对应的端口就开启了,进程关闭,则该端口也就关闭了。...下次若某个进程再次开启,则相应的端口也再次开启。而不要纯粹的理解为关闭掉某个端口,不过可以禁用某个端口。...1. linux查看端口状态命令 netstat -anp (注:加参数’-n’会将应用程序转为端口显示,即数字格式的地址,如:nfs->2049, ftp->21,因此可以开启两个终端,一一对应一下程序所对应的端口号...(注:有些端口通过netstat查不出来,更可靠的方法是”sudo nmap -sT -O localhost”) 3. linux关闭某个端口命令 1)通过iptables工具将该端口禁掉,如: “sudo

    54.9K40

    Linux端口查询

    '端口'解义 以下讲义,纯属个人所学理解,可能会有出入,仅参考。 端口分物理端口和应用端口。物理端口是物理设备的,比如笔记本上插网线的网口,就属于物理端口。...应用端口是虚拟的,是网络模型中传输层的一种含义,也叫网络端口。大家常听的tcp端口、udp端口,是用来监听网络信息传输的。...一般来说,一个应用或者一个服务对一个网络端口,网络信息传输到设备的物理端口,既网络模型中的物理层,经链路层、网络层传输到操作系统中,操作系统会根据网络信息中的目的端口来确认接受信息的应用或者服务。...列出正在监听的端口 netstat -at # 列出所有TCP端口 netstat -au # 列出所有UDP端口 netstat -ax # 列出所有...在Linux中,所有内容都是文件,你可以将套接字视为写入网络的文件。

    5.5K20

    Linux查看开放端口_linux查看对外端口

    active) interfaces: eth0 sources: services: dhcpv6-client http ssh ports: masquerade: no forward-ports: icmp-blocks...etc/selinux/config 修改 selinux 配置文件 将SELINUX=enforcing改为SELINUX=disabled,保存后退出 reboot #重启服务器 CentOS6 linux...查看并对外开放端口(防火墙拦截处理) 查看端口是否可访问:telnet ip 端口号 (如本机的35465:telnet localhost 35465) 开放的端口位于/etc/sysconfig...iptables -A和-I的区别](https://www.cnblogs.com/mustark/p/11189883.html) 若/etc/sysconfig/iptables不存在, 原因:在新安装的linux...命令随便写一条防火墙规则,如:iptables -P OUTPUT ACCEPT 使用service iptables save进行保存,默认就保存到了/etc/sysconfig目录下的iptables文件中 Linux

    83.9K30

    linux端口转发技术(单端口分发)

    端口转发映射的程序叫rinetd,下载地址,直接manke编译安装即可。...要跳转的IP 要跳转的端口;在每一单独的行中指定每个要转发的端口。...源地址和目的地址都可以是主机名或IP 地址,IP 地址0.0.0.0 将rinetd 绑定到任何可用的本地IP地址上: 例如将所有发往本机80端口的请求转发到192.168.4.247的80端口...:123 & 在本地监听188端口,并将请求转发至192.168.1.22的123端口 TCP4-LISTEN:在本地建立的是一个TCP ipv4协议的监听端口; reuseaddr...:绑定本地一个端口; fork:设定多链接模式,即当一个链接被建立后,自动复制一个同样的端口再进行监听 socat启动监听模式会在前端占用一个shell,因此需使其在后台执行。

    6.3K20

    Icmp protocol

    UDP的规则之一是,如果收到一份UDP数据报,而目的端口与某个正在使用的进程不符,那么UDP返回一个ICMP不可达报文。 (ICMP报文是在主机之间进行交换的,不是目的端口号。...UDP是从一个 端口号发给另一个端口号。) Filtering ICMP ICMPv6 Packets with Tcpdump 4.ICMP差错报文的产生?...ICMP知道如何解释原始IP数据报中的前8个字节,不论是UDP函数TCP,前8个字节都是源端口号和目的端口号,如果源端口号和目的端口号不符,就会产生ICMP端口不可达的差错报文,即产生了差错报文 5.ICMP...Exploring TCP Connection Time_Wait in Linux 8.ping执行打印的信息 输出字节数,是64;输出目的主机的IP地址,是通过DNS协议解析来的;输出icmp_seq...Linux Tcpdump: Filter ipv6 ntp ping packets ————————————————

    1.3K10

    Linux 实现端口转发

    本文讲述了如何在Linux下实现端口转发,以实现通过V**连接至远端开放给V**连接的计算机后,如何通过该计算机代理访问远端内网中其它计算机。...于是就有了下面的办法,用B公司开放的服务器做端口转发,将A公司对B公司数据库服务器的访问请求,通过开放服务器转发到数据库服务器,间接实现对数据库服务器的访问。...安装rinetd服务 http://www.boutell.com/rinetd/ 配置转发规则 vi /etc/rinetd.conf 规则内容为: 本机IP地址 本机端口A...目标IP地址 目标端口 规则生效 pkill rinetd rinetd -c /etc/rinetd.conf 查看地址映射 netstat -antup 接下来,在...A公司这边就可以通过访问该开放服务器的【端口A】实现对B公司数据库服务器的访问了。

    4.6K20

    Linux 释放占用端口

    场景 在使用 Swoole 扩展库的 WebSocket 服务时,直接退出终端,但是 WebSocket 使用的端口依然坚挺的在被占用着。 导致再次启动 WebSocket 服务失败。...释放占用端口 释放端口,需要完成三步操作: 找到系统当前所有的端口 找到对应端口在系统中的进程 ID(PID) 使用 kill -9 [PID] 命令结束进程 1....找到系统当前所有的端口 使用 netstat 命令查找本机各端口的网络连接情况 $ netstat -tln #结果如下 Active Internet connections (only servers...找到对应端口在系统中的进程 ID(PID) 依据查找到的 1997 端口找到对应进程, lsof -i :1997, 注意 : 冒号不要漏掉了 lsof -i:1997 #结果如下 COMMAND...参考: 每天一个linux命令(56):netstat命令

    11.3K10
    领券