【网络编程】第八章 传输层-udp(netstat+pidof+upd协议)


文章目录


一、linux常用网络命令

netstat

复制代码
netstat
netstat -l # 只列出listen状态服务
netstat -n # 将显示的信息用数字(id)代替
netstat -p # 显示端口和进程pid的关联
netstat -t # tcp
netstat -u # udp
netstat -a # 显示所有服务

pidof

获取某个进程名的进程 pid

复制代码
pidof 进程名

二、UPD协议

协议格式

  • 16位源端口号:表示数据从哪里来。
  • 16位目的端口号:表示数据要到哪里去。
  • 16位UDP长度:表示整个数据报(UDP首部+UDP数据)的长度。
  • 16位UDP检验和:如果UDP报文的检验和出错,就会直接将报文丢弃。

报头

定长报头

复制代码
struct udp_hdr
{
    unsigned int src_port:16;//源端口号
    unsigned int dst_port:16;//目的端口号
    unsigned int udp_len:16;//UDP长度
    unsigned int udp_check:16;//UDP检验和
}

udp 协议的特点

  • 无连接:知道对端ip:端口就直接进行数据传输,不需要建立连接。
  • 不可靠:没有确认机制,没有重传机制;如果网络故障该段无法发到对方,UDP协议层也不会给应用层返回任何错误信息。
  • 面向数据报:不能够灵活的控制读写数据的次数和数量,必须一次性读完,不会拆分也不会合并。

udp缓冲区

  • UDP没有真正意义上的发送缓冲区。调用sendto会直接交给内核,由内核将数据传给网络层协议进行后续的传输动作。

  • UDP具有接收缓冲区。只是一味地接收,并不能保证报文的顺序;如果缓冲区满了,再到达的UDP数据就会被丢弃。

  • UDP的socket既能读,也能写,因此UDP是全双工的。

udp 使用注意事项

UDP 报文中的 16 位长度字段,限制了 udp 报文的长度为 64KB,有效载荷选用 512 字节


相关推荐
KoiHeng1 小时前
网络原理相关内容(二)
网络
独行soc2 小时前
2026年渗透测试面试题总结-25(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
盟接之桥3 小时前
制造业EDI数字化:连接全球供应链的桥梁
linux·运维·服务器·网络·人工智能·制造
键盘鼓手苏苏3 小时前
Flutter for OpenHarmony:debounce_throttle 防抖与节流的艺术(优化用户交互与网络请求) 深度解析与鸿蒙适配指南
网络·flutter·交互
XiaoHu02073 小时前
Linux网络编程(第四弹)
linux·网络·智能路由器
REDcker3 小时前
HTTP 协议发展详解:从 HTTP/1 到 HTTP/3
网络·网络协议·http
AC赳赳老秦4 小时前
2026 智能制造趋势:DeepSeek 助力“黑灯”工厂运营,实现生产流程自动化
网络·数据结构·算法·安全·web安全·prometheus·deepseek
乾元4 小时前
数据投毒:如何通过训练数据污染埋下“后门”
运维·人工智能·网络协议·安全·网络安全·系统架构·自动化
小鸡食米4 小时前
Keepalived高可用
运维·服务器·网络
白太岁5 小时前
操作系统开发:(10) 线程创建与调度的底层原理:从硬件行为解释线程
c语言·网络·系统架构