Nodejs中net模块多次Socket.setTimeout无法覆盖之前函数,导致叠加执行问题解决


Hi, I’m Shendi


Nodejs中net模块多次Socket.setTimeout无法覆盖之前函数,导致叠加执行问题解决




问题描述

在 Nodejs 中,net 模块的 Socket 的 setTimeout 函数是设置超时时间,如果多次设置,超时时间会是最后一次的时间,但设置的函数会叠加执行,例如如下代码

const server = net.createServer((socket) => {socket.setTimeout(2000, () => {console.log('Socket timeout after 2 seconds');});socket.setTimeout(5000, () => {console.log('Socket timeout after 5 seconds');  });socket.setTimeout(10000, () => {console.log('Socket timeout after 10 seconds');  });
});server.listen(8080, () => {  console.log('Server listening on port 8080');  
});const client = new net.Socket();  
client.connect(8080, 'localhost', () => {  console.log('Connected to server');  
});

执行后会发现,10秒后,设置的函数都被执行了。

在这里插入图片描述



问题解决

通过查看Socket.setTimeout的注释,有如下描述

在这里插入图片描述

The optional callback parameter will be added as a one-time listener for the ‘timeout’ event.

即,同 on 添加监听,那么可以通过移除监听来解决

有两种方式,一种移除指定监听的单个监听,这种需要将函数保存起来,一种是移除指定监听的所有监听

对于我的需求,只需要保留最后一次设置,那么使用移除所有就可以了

在这里插入图片描述

代码如下

const server = net.createServer((socket) => {socket.setTimeout(2000, () => {console.log('Socket timeout after 2 seconds');});socket.setTimeout(5000, () => {console.log('Socket timeout after 5 seconds');  });socket.removeAllListeners("timeout");socket.setTimeout(10000, () => {console.log('Socket timeout after 10 seconds');  });
});server.listen(8080, () => {  console.log('Server listening on port 8080');  
});const client = new net.Socket();  
client.connect(8080, 'localhost', () => {  console.log('Connected to server');  
});

输出如下

在这里插入图片描述




END

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

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

相关文章

038、语义分割

之——介绍与数据集 杂谈 语义分割,语义分割(Semantic Segmentation)方法-CSDN博客: 语义分割是计算机视觉领域的一项重要任务,旨在将图像中的每个像素分配到其对应的语义类别中。与物体检测或图像分类不同,语义分割不仅要识别图像…

QGroundControl源码编译的三种方法

1.使用QtCreator编译: 下载qgroundcontrol源码 https://github.com/mavlink/qgroundcontrol.git 克隆 同步子模块 使用打开qgroundcontrol.pro 打开前要求先安装qt 5.15.2

Mysql之单行函数

Mysql之单行函数 单行函数数值类型函数字符串类型的函数日期和时间函数加密与解密函数信息函数 单行函数 函数的定义 函数在计算机语言的使用中贯穿始终,函数的作用是什么呢?它可以把我们经常使用的代码封装起来, 需要的时候直接调用即可。这…

nacos网关

目录 拉取docker镜像 环境配置 网关搭建架构 wemedia-gateway网关配置 依赖 启动类配置 网关yml配置 nacos配置中心配置网关 wdmedia服务配置 依赖 启动类配置 yml配置 nacos配置 nacos中的配置共享 nacos配置 wmedia模块中yml的配置 参考:https://blog.csdn.net/…

Spark 平障录

Profile Profile 是最重要的第一环。 利用好 spark UI 和 yarn container log分析业务代码,对其计算代价进行预判建设基准,进行对比,比如application id 进行对比,精确到 job DAG 环节 充分利用 UI Stage 页面 页头 summary&…

element-plus 表格-合并单元格

利用表格:span-method"" 方法实现合并单元格 合并前 合并后 重点代码generateIndexGroups &#xff0c;找到合并的单元格的index号 代码实现如下 <template><h2>实现表格的合并</h2><div><!-- :span-method"arraySpanMethod&quo…

项目出错汇总

java: 错误: 无效的源发行版&#xff1a;15 java: 无效的目标发行版: 17 四步加上这个,改一下

【diffuser系列】ControlNet

ControlNet: TL;DRControl TypeStableDiffusionControlNetPipeline1. Canny ControlNet1.1 模型与数据加载1.2 模型推理1.3 DreamBooth微调 2. Pose ControlNet2.1 数据和模型加载2.2 模型推理 ControlNet: TL;DR ControlNet 是在 Lvmin Zhang 和 Maneesh Agrawala 的 Adding …

gd32关于IO引脚配置的一些问题

一、gd32f103的PA15问题 1、 #define GPIO_SWJ_NONJTRST_REMAP ((uint32_t)0x00300100U) /*!< full SWJ(JTAG-DP SW-DP),but without NJTRST */ #define GPIO_SWJ_SWDPENABLE_REMAP ((uint32_t)0x00300200U) /*!< JTAG-DP disabled and SW-DP enab…

c语言:解决数组有关的删除,排序,合并等问题。

题目1&#xff1a;判断数组是否有序&#xff08;升序或者降序&#xff09; 思路和代码&#xff1a; #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> int main() {int a 0;scanf("%d", &a);int arr[50];int flag1 0;//是降序int flag2 0;//是升序…

Zabbix实现故障自愈

一、简介 Zabbix agent 可以运行被动检查和主动检查。 在被动检查模式中 agent 应答数据请求。Zabbix server&#xff08;或 proxy&#xff09;询求数据&#xff0c;例如 CPU load&#xff0c;然后 Zabbix agent 返还结果。 主动检查处理过程将相对复杂。Agent 必须首先从 Z…