TCP的连接建立及报文段首部格式

粘包问题:

原因 :TCP流式套接字;数据与数据之间没有边界;导致可能多次的数据粘到一起。

解决办法:

  1. 规定一些数据与数据之间的间隔符,如:"\aa\", "\r\n"。
  2. 指定要发送的数据长度。
  3. 自己将数据打包。

TCP的连接建立:

1.用三次握手建立TCP连接:
2.TCP的连续释放(四次挥手)

TCP报文段的首部格式:

一个TCP报文段分为首部和数据两部分,但TCP的全部功能都体现在其首部各字段的作用。

TCP报文段首部的前20个字节是固定的,后面有4N字节是根据需要而增加的选项(N是整数))。因此TCP首部的最小长度是20字节。(详细内容参考《计算机网络》第205页。

常用网络测试工具:

  1. ifconfig:查看主机上网卡网络信息;
  2. ping:测试两台主机之间是否连通;
  3. telent:远程登陆工具;
  4. ssh:硬件(开发板)
  5. netstat:查看当前主机上,活动的网络进程相关状态信息;
  6. arp:address resolution protocol;

抓包工具(tcpdump):

tcp.port == 50000 && tcp.ip == 192.168.0.183

el ----> wireshark(抓包/监听)

wireshark(可视化界面)

过滤规则:

(1)根据IP地址过滤:ip.src == x.x.x.x ip.dst == x.x.x.x

(2)根据端口过滤: tcp.srcport == xx; tcp.dstport == xx;

udp.srcport == xx; udp.dstport == xx;

(3)根据协议类型过滤:tcp; udp; icmp...........telnet;

(4)任意组合以上条件抓包:tcp; udp; icmp...........telnet;

1)与(and):ip.src == 192.168.1.100 and tcp.dstport == 9999

2)或(or):ip.src == 192.168.1.100 or ip.dst == 192.168.1.102

tcp host 192.168.1.100

相关推荐
爱学习 爱分享6 小时前
k8s 开启防火墙,容器内部无法访问外部 ip
tcp/ip·容器·kubernetes
发光小北6 小时前
Profinet 从站转 EtherNet/IP 从站网关如何应用?
网络·网络协议·tcp/ip
wangl_926 小时前
Modbus RTU 与 Modbus TCP 深入指南-Wireshark抓包分析实战
网络协议·tcp/ip·wireshark·tcp·modbus·rtu
高锰酸钾_7 小时前
计算机网络-链路层-介质访问控制
网络·计算机网络
源远流长jerry8 小时前
Linux 网络发送机制深度解析:从应用到网线
linux·服务器·网络·网络协议·tcp/ip
goyeer9 小时前
【ITIL4】32服务实践 - 问题管理(Problem Management)
linux·运维·服务器·企业数字化·it管理·itil·it治理
handler019 小时前
UDP协议与网络通信知识点
c语言·网络·c++·笔记·网络协议·udp
怀旧,9 小时前
【Linux网络编程】8. 网络层协议 IP
linux·网络·tcp/ip
cen__y10 小时前
Linux11(网络编程)
linux·运维·服务器·c语言·网络·网络协议·tcp/ip
CableTech_SQH10 小时前
商业地产和高端酒店该怎么选综合布线解决方案?
运维·服务器·网络