常用网络测试工具以及解决tcp协议带来得问题

常用网络测试工具以及解决tcp协议带来得问题因为是文件 IO 标准 IO 的问题 读写问题 因为 fgets 先去底层取数据 我们把东西拿走了 而等文件 IO 去取数据的时候东西已经没有了

大家好,欢迎来到IT知识分享网。

一、解决粘包问题
1.1、tcp的特点

面向字节流特点,会造成可能数据与数据发送到一块,成为粘包,数据之间不区分

1.2、拆包

因为缓冲区的大小,一次性发送的数据会进行拆分(大小不符合的时候)

就和水一样一次拆一次沾到一块,不好对数据进行拆分

字节流就是像水一样,一个接着一个往过流,字节流,紧挨着,

多次发的东西一次性接受

在底层下面,socket 会在发送数据会等一下,时间到了就一次性发送

1.3、解决粘包问题

原因:

tcp 流式套接字

数据与数据之间没有边界

导致

可能多次的数据粘到一起

解决:

1、规定一些数据与数据之间的 间隔符

eg、”\aa”\r\n”

2、可以指定要发送的数据的长度

3、自己将数据打包

eg、 struct msg { int size; char data[100] }

相当于自己把自己打成一个包,和其他人不是一个,没有办法融合

2、加延时,让先把东西发过去,间隔一下,相当于就是跑出去了,被拉了一下,两人错开了

1.4、程序过程中遇到的问题

因为是文件IO,标准IO的问题,读写问题,因为fgets,先去底层取数据,我们把东西拿走了,而等文件IO,去取数据的时候东西已经没有了。

 signal(SIGCHLD,handler); char buf1[1024] = "3.c"; write(fd,buf1,strlen(buf1)+1); //sleep(1); int file = open(buf1,O_RDONLY); write(fd,"\r\n",2);

解决办法

在网络里面有专门的读写操作

fgets()后面的参数需要一个流指针,后面是一个流指针,遇到\n结束,并且将\n读到

这样我们就可以将文件描述符,转换成字符流指针,通过fgets来获取这些信息,再设置一个标志符,来进行区分所发送的信息。

send()发数据

ssize_t send(int sockfd, const void *buf, size_t len, int flags);

recv()

ssize_t recv(int sockfd, void *buf, size_t len, int flags);

flag是指可以指定在网络中接收的方式

前面三个参数和read参数一致

 二、常用网络测试工具
2.1、# ubuntu开启telnet服务  

开启telnet结果图

常用网络测试工具以及解决tcp协议带来得问题 2.2、ssh安装
    • /ssh登录 ubuntu 需要安装以下的服务
      sudo apt-get install openssh-server openssh-client
2.3、 抓包安装
  1. sudo apt install wireshark
  2. sudo wireshark(启动)

常用网络测试工具以及解决tcp协议带来得问题

 2.4、wireshark过滤使用

过滤规则:

  • 1、根据ip地址过滤
  • ip.srC = x.X.X.X
  • ip.dst =- x.x.x.x
  • 根据端口过滤:tcp.srcportXX;二
  • tcp.dstportXX;二三
  • udp.srcportZ-XX;
  • udp.dstportXX:
  • 根据协议类型过滤:
  • tcp udp icmptelnet
  • 任意组合以上条件抓包:
  • 如果与的关系:and
  • ip.src == 192.168.1.100 and tcp.dstport == 9999
  • 如果或关系:Or
  • ip.src == 192.168.1.100 or ip.dst == 192.168.1.102
  • tcp host 192.168.1.100
2.5、netstat 测试查看网络端口使用情况
  • //正在活动的 常看tcp的//用的最多的
  • netstat -anp
  • -a //a] ]
  • 直接显示 ip port 的数字形式-n ll
  • -p //显示 进程的 程序名 和 pid
  • netstat-n                =–>列出当前所有网络端口使用情况
  • -tnetstat-n              =–>列出所有TCP通信的端口信息
  • netstat-n-U             =–>列出所有UDP通信的端口信息
  • netstat -n -i             =–>列出默认网络接口(网卡)上的通信信息
  • netstat -lnp | grep 8888             i===>查看指定端口上的通信详情

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/136734.html

(0)
上一篇 2025-06-25 15:26
下一篇 2025-06-25 15:33

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信