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

2024-08-23 19:44

本文主要是介绍常用网络测试工具以及解决tcp协议带来得问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、解决粘包问题
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参数一致

 二、常用网络测试工具

ifconfig //查看主机上,网卡网络信息
ping                //测试 两台主机之间是否连通
telnet                //远程登录工具
ssh                    //硬件(开发板)
netstat                //查看当前主机上,活动的网络进程的相关的状态信息
arp                        //(ipc找mac)

2.1、# ubuntu开启telnet服务  

sudo apt-get install openbsd-inetd
sudo apt-get install telnetd
sudo /etc/init.d/openbsd-inetd restart
注意:
安装之前,确保ubuntu能上网
ping www.baidu.com
# 查看 telnet服务是否开启
sudo netstat -a | grep telnet

开启telnet结果图

 2.2、ssh安装
    • /ssh登录 ubuntu 需要安装以下的服务
      sudo apt-get install openssh-server openssh-client
2.3、 抓包安装
  1. sudo apt install wireshark
  2. sudo wireshark(启动)

 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===>查看指定端口上的通信详情

这篇关于常用网络测试工具以及解决tcp协议带来得问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1100323

相关文章

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也