TCP常见问题详解

本篇文章我们介绍一下 在我们的面试中和实际开发中使用TCP遇到的问题

1.TCP在什么情况下出现大量的time_event

什么是time_event?

我们首先要弄清楚TIME_WAIT状态是什么?TIME_WAIT状态是主动关闭TCP连接的一方(即先发起FIN包的一方),在发送完最后一个ACK包后进入的状态。系统需要在TIME_WAIT状态下等待2MSL(maximum segment lifetime )后才能释放连接(端口)。根据RFC 793 MSL是2分钟,一般的TCP实现有30秒、1分钟和2分钟不等。进入TIME_WAIT状态等待2MSL主要有两个目的:一方面是主动关闭连接的一方在对方没有收到最后一个ACK包时(这时对方还会重发FIN,收到两个FIN的时间间隔一定小于2MSL)有时间可以重发ACK包,另一方面处于TIME_WAIT的连接(IP和端口组合)不能重用,这样可以保证被重新分配的socket不会受到之前残留的延迟重发报文影响。

由于主动关闭TCP连接的一方才会进入TIME_WAIT状态,一般情况服务器端不会出现TIME_WAIT状态,因为大多数情况都是客户端主动发起连接并主动关闭连接。但是某些服务如pop/smtp、ftp却是服务端收到客户端的QUIT命令后主动关闭连接,这就造成这类服务器上容易出现大量的TIME_WAIT状态的连接,而且并发量越大处于此种状态的连接越多。另外,对于被动关闭连接的服务在主动关闭客户端非法请求或清理长时间不活动的连接时(这种情况很可能是客户端程序忘记关闭连接)也会出现TIME_WAIT的状态。

2.TCP粘包解决的办法

黏包问题是指在传输过程中多个数据包被合并成了一个或者一个数据包被拆分成了多个,造成接收方无法正确解析。解决黏包问题的方法主要有以下两种:

  1. 固定包头接收:发送方在每个数据包前加上固定长度的头部信息,接收方先读取头部信息获取数据包长度,再根据长度截取对应的数据。这样可以保证每次接收到的数据都是完整的。

  2. 指定内存长度:发送方在每个数据包前不添加任何头部信息,而是在尾部添加一个特殊字符(例如换行符“\n”),接收方按照特殊字符进行切割,并且预先给缓存区分配足够长的空间来容纳整个消息。这样也能确保接收到的数据都是完整的。

 解决TCP粘包的代码实例:

核心思想:在C++中,处理TCP粘包问题通常涉及到自定义协议来区分数据包。这意味着需要设计一种机制来标记每个数据包的开始和结束。

 服务器端:

#include <boost/asio.hpp>  
#include <iostream>  
#include <vector>  using boost::asio::ip::tcp;  class session : public std::enable_shared_from_this<session> {  
public:  session(tcp::socket socket) : socket_(std::move(socket)) {}  void start() {  do_read();  }  private:  void do_read() {  auto self(shared_from_this());  char buffer[1024];  socket_.async_read_some(boost::asio::buffer(buffer),  [this, self](boost::system::error_code ec, std::size_t length) {  if (!ec) {  std::cout.write(buffer, length);  std::cout << std::endl;  do_read();  }  });  }  tcp::socket socket_;  
};  int main(int argc, char* argv[]) {  try {  if (argc != 2) {  std::cerr << "Usage: async_tcp_echo_server <port>\n";  return 1;  }  boost::asio::io_context io_context;  tcp::acceptor acceptor(io_context, tcp::endpoint(tcp::v4(), std::atoi(argv[1])));  for (;;) {  tcp::socket socket(io_context);  acceptor.async_accept(socket,  [&](boost::system::error_code ec) {  if (!ec) {  std::make_shared<session>(std::move(socket))->start();  }  });  }  io_context.run();  }  catch (std::exception& e) {  std::cerr << "Exception: " << e.what() << "\n";  }  return 0;  
}

客户端代码:

#include <boost/asio.hpp>  
#include <iostream>  using boost::asio::ip::tcp;  int main(int argc, char* argv[]) {  try {  if (argc != 3) {  std::cerr << "Usage: async_tcp_echo_client <host> <port>\n";  return 1;  }  boost::asio::io_context io_context;  tcp::resolver resolver(io_context);  tcp::resolver::results_type endpoints = resolver.resolve(argv[1], argv[2]);  tcp::socket socket(io_context);  boost::asio::connect(socket, endpoints);  for (int i = 0; i < 5; ++i) {  std::string message = "Hello, world! (" + std::to_string(i) + ")\n";  boost::asio::write(socket, boost::asio::buffer(message));  }  io_context.run();  }  catch (std::exception& e) {  std::cerr << "Exception: " << e.what() << "\n";  }  return 0;  
}

 总结:本篇文章描述了C++的常见的一些问题  粘包 时间等待线程  这些在我们的开发中有时候会遇到 我们要积极的解决 否则就会出现很多问题

好了 本篇文章就到这里结束了 在这里我给大家推荐一个性价比很高的课程:

 https://xxetb.xetslk.com/s/2PjJ3T

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/685892.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

node+vue3+mysql前后分离开发范式——实现视频文件上传并渲染

文章目录 ⭐前言⭐ 功能设计与实现💖 node上传文件写入file_map映射表💖 vue3前端上传文件回显⭐ 效果⭐结束⭐前言 大家好,我是yma16,本文分享关于 node+vue3+mysql前后分离开发范式——实现视频文件上传并渲染。 技术选型 前端:vite+vue3+antd 后端:node koa 数据库…

有了NULL,为什么C++还需要nullptr?

目录 1.引言 2.类型安全 3.函数重载 4.代码清晰性 5.示例 6.总结 1.引言 在C编程中&#xff0c;nullptr是一个类型安全的空指针常量&#xff0c;自C11起被引入。然而&#xff0c;在此之前&#xff0c;程序员们通常使用NULL或0来表示空指针。那么&#xff0c;为什么有了N…

在 MySQL 数据库中创建新账号并分配权限

本文介绍如何在 MySQL 数据库中创建新账号并为其分配特定数据库实例的权限。 一、连接到 MySQL 数据库 首先&#xff0c;使用 MySQL 客户端或其他数据库管理工具连接到 MySQL 数据库服务器。你可以使用以下命令。 mysql -u root -p 然后输入密码以登录到 MySQL。 二、创建新…

Leetcode 496. 下一个更大元素 I

题意理解&#xff1a; nums1 中数字 x 的 下一个更大元素 是指 x 在 nums2 中对应位置 右侧 的 第一个 比 x 大的元素。 给你两个 没有重复元素 的数组 nums1 和 nums2 &#xff0c;下标从 0 开始计数&#xff0c;其中nums1 是 nums2 的子集。 对于每个 0 < i < nums1.le…

JVM-垃圾回收(标记算法,收集器)

申明&#xff1a;文章内容是本人学习极客时间课程所写&#xff0c;文字和图片基本来源于课程资料&#xff0c;在某些地方会插入一点自己的理解&#xff0c;未用于商业用途&#xff0c;侵删。 原资料地址&#xff1a;课程资料 垃圾回收的基本原理 1 什么是垃圾&#xff1f; 在…

Linux :sh、可执行文件,无法使用. / 安装执行

问题 1. 我写了个 lib.sh 文件&#xff0c;发现我可以用 sh lib.sh 来执行&#xff0c;都是无法用 ./lib.sh执行。 2. 我发现当这个 lib.sh 文件用 ./lib.sh 无法执行的时候&#xff0c;我在终端打出 "./li " 它是无法帮我自动补全的。 其实就是这个时候 lib.s…

re:从0开始的CSS之旅 20. 渐变(暂完结撒花)

1. 渐变 渐变&#xff1a;使背景颜色有逐渐变化的效果 1. 线性渐变 background-image: linear-gradient(to left top, #c7edcc, #fde6e0, #dce2f1); 第一个参数可选值为&#xff1a; to top/right/left/bottom/top right/…… 第二个参数到第n个参数为需要渐变的颜色&#…

阿里云ECS香港服务器性能强大_安全可靠香港免备案服务器

阿里云香港服务器中国香港数据中心网络线路类型BGP多线精品&#xff0c;中国电信CN2高速网络高质量、大规格BGP带宽&#xff0c;运营商精品公网直连中国内地&#xff0c;时延更低&#xff0c;优化海外回中国内地流量的公网线路&#xff0c;可以提高国际业务访问质量。阿里云服务…

视觉slam十四讲学习笔记(六)视觉里程计 1

本文关注基于特征点方式的视觉里程计算法。将介绍什么是特征点&#xff0c;如何提取和匹配特征点&#xff0c;以及如何根据配对的特征点估计相机运动。 目录 前言 一、特征点法 1 特征点 2 ORB 特征 FAST 关键点 BRIEF 描述子 3 特征匹配 二、实践&#xff1a;特征提取…

《Linux 简易速速上手小册》第2章: 命令行的艺术(2024 最新版)

文章目录 2.1 基本 Linux 命令2.1.1 重点基础知识2.1.2 重点案例&#xff1a;整理下载文件夹2.1.3 拓展案例 1&#xff1a;批量重命名文件2.1.4 拓展案例 2&#xff1a;查找并删除特定文件 2.2 文件和目录管理2.2.1 重点基础知识2.2.2 重点案例&#xff1a;部署一个简单的网站2…

SpringMVC速成(二)

文章目录 SpringMVC速成&#xff08;二&#xff09;1.SSM整合1.1 流程分析1.2 整合配置步骤1&#xff1a;创建Maven的web项目步骤2:添加依赖步骤3:创建项目包结构步骤4:创建SpringConfig配置类步骤5:创建JdbcConfig配置类步骤6:创建MybatisConfig配置类步骤7:创建jdbc.properti…

《Go 简易速速上手小册》第2章:控制结构与函数(2024 最新版)

文章目录 2.1 条件语句&#xff1a;决策的艺术2.1.1 基础知识讲解2.1.2 重点案例&#xff1a;用户角色权限判断实现用户角色权限判断扩展功能实现代码功能扩展&#xff1a;添加或删除用户 2.1.3 拓展案例 1&#xff1a;成绩等级判断实现成绩等级判断功能实现代码扩展功能&#…

Electron实战之进程间通信

进程间通信&#xff08;IPC&#xff09;并非仅限于 Electron&#xff0c;而是源自甚至早于 Unix 诞生的概念。尽管“进程间通信”这个术语的确创造于何时并不清楚&#xff0c;但将数据传递给另一个程序或进程的理念可以追溯至 1964 年&#xff0c;当时 Douglas McIlroy 在 Unix…

Windows 连接共享文件夹 切换/退出账号操作

工作中遇到个问题&#xff0c;登录公司内部共享文件夹&#xff0c;使用自己的账号&#xff0c;但需要切换别人账号找东西时&#xff0c;没有发现登出的地方。在网上找了两种方法&#xff1a;通过命令行登出账号的方法 &#xff08;1&#xff09;打开cmd命令提示符&#xff0c;…

对待不合理需求,前端工程师如何优雅的say no!

曾经有位老板&#xff0c; 每次给前端提需求&#xff0c;前端都说实现不了&#xff0c;后来他搜索了一下&#xff0c;发现网上都有答案。他就在招聘要求上加了条&#xff1a;麻烦你在说不行的时候&#xff0c;搜索一下。 上面是一个段子&#xff0c;说的有点极端了&#xff0c;…

Java面试宝典——多线程(一)

可关注微信公众号“假装正经的程序员”与博主取得联系,回复“多线程”可获取详细答案 本篇为多线程基础内容,部分问题相对比较“刁钻”,却又是中高级开发工程师必须掌握的知识点,因此本篇内容需要全部熟知 问题 什么是volatile volatile的实现原理 ConcurrentHashMap如何…

牛客小白月赛87 E.小苯的数组构造【构造+贪心】

原题链接&#xff1a;https://ac.nowcoder.com/acm/contest/73854/E 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K Special Judge, 64bit IO Format: %lld 题目描述 大白熊给了小苯一个长度为 n 的数组…

Java集合篇之深入解析ArrayList,这六问你答的上来吗?

写在开头 开年第一篇&#xff0c;先祝各位新的一年身体健康&#xff0c;学业有成&#xff0c;事业有成哈&#xff0c;春节期间就是咔咔乱吃&#xff0c;咔咔乱玩&#xff0c;把学习都抛一边子去了&#xff0c;已经9天没有学习了&#xff0c;深深的懊悔&#xff0c;从今天开始&…

Leetcode1423.可获得的最大点数

文章目录 题目原题链接思路&#xff08;逆向思维&#xff09; 题目 原题链接 Leetcode1423.可获得的最大点数 思路&#xff08;逆向思维&#xff09; 由题目可知&#xff0c;从两侧选k张&#xff0c;总数为n张&#xff0c;即从中间选n - k张 nums总和固定&#xff0c;要选k张最…

[CTF]-PWN:C++文件更换libc方法(WSL)

C文件与C文件更换libc有很多不一样的地方&#xff0c;我是在写buu的ciscn_2019_final_3才意识到这个问题&#xff0c;C文件只需要更换libc和ld就可以了&#xff0c;但是C文件不同&#xff0c;除了更换libc和ld&#xff0c;它还需要更换libstdc.so.6和libgcc_s.so.1 更换libc和…