close_wait的影响和消除

本文深入解析TCP连接中close_wait状态的原理,详细解释为什么会出现该状态,以及可能导致的原因,如服务端数据未处理完成或未调用close(socket)。同时提供了解决close_wait状态的方法,包括改善服务端代码和使用keepalive保活机制来检测和处理半关闭连接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

close_wait

close_wait是TCP结束连接四次握手时被动关闭的一端出现的状态。如下图所示:
这里写图片描述

为什么会出现保持在close_wait呢?很明显是被动关闭的一方未发FIN导致其一直处于CLOSE_WAIT。
那么为什么被动关闭的一方未发FIN了?很可能是被动关闭的一方还用数据没有发完,导致FIN没发。或者是
服务端没有调用TCP的close(socket)。

close_wait的影响

Close_Wait会占用一个连接,数量过多,就使可用的连接减少,还会并占用系统非换页内存。 而linux可用连接也是有限制的。如果不加处理,会极大的影响服务器的性能。

close_wait的解决方法

一是对服务端代码进行改善,查看服务端代码在处理完毕客户端请求,并在客户端数据处理完毕后,有没有进行使用close(socket)操作.
二是使用keepalive保活机制来对这种半关闭连接进行检测
int keepAlive = 1;//开启keepalive属性
int keepIdle = 60;//如果60秒内没有任何数据往来,则进行探测
int keepInterval = 6;//探测时发包的时间间隔为6秒
int keepCount = 3;//探测尝试的次数,如果第一次探测包就收到相应,以后的2次就不再发
//keepalive
setsockopt(m_iSock,SOL_SOCKET, SO_KEEPALIVE, (void*)&keepAlive, sizeof(int));
setsockopt(m_iSock,SOL_TCP,TCP_KEEPIDLE,(void*)&keepIdle, sizeof(int));
setsockopt(m_iSock,SOL_TCP, TCP_KEEPINTVL,(void*)&keepInterval,sizeof(int));
setsockopt(m_iSock,SOL_TCP, TCP_KEEPCNT,(void*)&keepCount,sizeof(int));

//IIC所有操作函数 void MAX30102_IIC_Init(void); //初始化IIC的IO口 void MAX30102_IIC_Start(void); //发送IIC开始信号 void MAX30102_IIC_Stop(void); //发送IIC停止信号 void MAX30102_IIC_Send_Byte(u8 txd); //IIC发送一个字节 u8 MAX30102_IIC_Read_Byte(unsigned char ack);//IIC读取一个字节 u8 MAX30102_IIC_Wait_Ack(void); //IIC等待ACK信号 void MAX30102_IIC_Ack(void); //IIC发送ACK信号 void MAX30102_IIC_NAck(void); //IIC不发送ACK信号 void MAX30102_IIC_Write_One_Byte(u8 daddr,u8 addr,u8 data); void MAX30102_IIC_Read_One_Byte(u8 daddr,u8 addr,u8* data); void MAX30102_IIC_WriteBytes(u8 WriteAddr,u8* data,u8 dataLength); void MAX30102_IIC_ReadBytes(u8 deviceAddr, u8 writeAddr,u8* data,u8 dataLength); //MAX30102所有操作函数 void MAX30102_Init(void); void MAX30102_Reset(void); u8 M30102_Bus_Write(u8 Register_Address, u8 Word_Data); u8 max30102_Bus_Read(u8 Register_Address); void max30102_FIFO_ReadWords(u8 Register_Address,u16 Word_Data[][2],u8 count); void max30102_FIFO_ReadBytes(u8 Register_Address,u8* Data); void maxim_max30102_write_reg(uint8_t uch_addr, uint8_t uch_data); void maxim_max30102_read_reg(uint8_t uch_addr, uint8_t *puch_data); void maxim_max30102_read_fifo(uint32_t *pun_red_led, uint32_t *pun_ir_led); //心率血氧算法所有函数 void maxim_heart_rate_and_oxygen_saturation(uint32_t *pun_ir_buffer , int32_t n_ir_buffer_length, uint32_t *pun_red_buffer , int32_t *pn_spo2, int8_t *pch_spo2_valid , int32_t *pn_heart_rate , int8_t *pch_hr_valid); void maxim_find_peaks( int32_t *pn_locs, int32_t *pn_npks, int32_t *pn_x, int32_t n_size, int32_t n_min_height, int32_t n_min_distance, int32_t n_max_num ); void maxim_peaks_above_min_height( int32_t *pn_locs, int32_t *pn_npks, int32_t *pn_x, int32_t n_size, int32_t n_min_height ); void maxim_remove_close_peaks( int32_t *pn_locs, int32_t *pn_npks, int32_t *pn_x, int32_t n_min_distance ); void maxim_sort_ascend( int32_t *pn_x, int32_t n_size ); void maxim_sort_indices_descend( int32_t *pn_x, int32_t *pn_indx, int32_t n_size); // void max301
03-11
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值