HTTP超时时间设置

在进行超时时间设置之前我们需要了解一次http请求经历的过程

  1. 浏览器进行DNS域名解析,得到对应的IP地址
  2. 根据这个IP,找到对应的服务器建立连接(三次握手)
  3. 建立TCP连接后发起HTTP请求(一个完整的http请求报文)
  4. 服务器响应HTTP请求,返回数据(服务器如何响应)
  5. 客户端对页面进行渲染呈现给用户
  6. 服务器关闭TCP连接(四次挥手)

在客户端和服务器之间通常有一层网关来负责路由和负载均衡:

DNS和TCP的超时时间通常由系统指定,DNS默认为5s,TCP建了超时默认为127s

所以下面从客户端、网关、服务端三个方面来讲解下HTTP请求的超时时间设置:

1、客户端设置

以JS为例

(1)使用XMLHttpRequest

var xhr = new XMLHttpRequest();
xhr.open('GET', 'http://example.com/api', true);// 设置超时时间,单位是毫秒
xhr.timeout = 2000; // 2秒后超时// 定义超时处理逻辑
xhr.ontimeout = function () {console.error("The request for " + url + " timed out.");
};xhr.onload = function () {// 请求成功的处理逻辑if (xhr.status >= 200 && xhr.status < 300) {console.log('The request was successful!', xhr.responseText);} else {console.error('The request failed!', xhr.status);}
};xhr.onerror = function () {// 请求失败的处理逻辑console.error('The request encountered an error.');
};xhr.send();

(2)使用fetch

const url = 'http://example.com/api';// 设置超时时间
const timeout = 2000; // 2秒后超时// 创建一个超时的Promise
const timeoutPromise = new Promise((resolve, reject) => {setTimeout(() => {reject(new Error('Request timed out'));}, timeout);
});// 发起fetch请求
const fetchPromise = fetch(url);// 使用Promise.race同时执行请求和超时Promise,哪个先完成就处理哪个
Promise.race([fetchPromise, timeoutPromise]).then(response => {// 检查是否响应成功if (!response.ok) {throw new Error('Network response was not ok');}return response.text();}).then(data => {// 请求成功的处理逻辑console.log('The request was successful!', data);}).catch(error => {// 请求失败或超时的处理逻辑console.error('Failed!', error);});

2、网关超时时间设置

以nginx为例:

在nginx.conf配置文件中可以指定超时时间

server {location / {proxy_pass http://backend_server;proxy_connect_timeout 5s;proxy_read_timeout 10s;proxy_send_timeout 5s;}
}

其中:

  1. 连接超时(Connection Timeout): 这是指客户端尝试与服务器建立连接时的最大等待时间。如果在这个时间内没有建立连接(例如,服务器没有响应或者网络延迟很高),客户端就会放弃尝试并抛出一个超时异常。

  2. 读超时(Read Timeout): 读超时是指客户端与服务器连接成功后,等待服务器发送数据的最大时间。如果在这个时间内客户端没有收到任何数据,就会认为读取操作超时并抛出异常。这通常发生在服务器处理请求的时间过长,或者网络传输延迟导致数据包迟迟未到达客户端。

  3. 写超时(Write Timeout): 写超时是指在客户端尝试向服务器发送数据时的最大等待时间。如果客户端在这段时间内未能完成数据的发送,就会认为写操作超时。这可能是因为网络速度慢或者服务器处理写入请求的速度慢。

3、服务端超时时间设置

以Tomcat为例:

可以在server.xml 文件中指定服务器的超时时间,如下所示:

<Connector port="8080" protocol="HTTP/1.1"connectionTimeout="20000"redirectPort="8443"readTimeout="15000"writeTimeout="15000" />

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

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

相关文章

[单机]完美国际_V155_GM工具_VM虚拟机

[端游] 完美国际单机版V155一键端PC电脑网络游戏完美世界幻海凌云家园 本教程仅限学习使用&#xff0c;禁止商用&#xff0c;一切后果与本人无关&#xff0c;此声明具有法律效应&#xff01;&#xff01;&#xff01;&#xff01; 教程是本人亲自搭建成功的&#xff0c;绝对是…

出海企业哪种组网方案更省事?

对于出海企业而言&#xff0c;建立跨地区的数据传输和协同工作至关重要&#xff0c;以提升运营效率。因此&#xff0c;网络构建变得迫在眉睫。通过构建企业组网&#xff0c;企业能够加强与海外分支、客户和合作伙伴之间的联系&#xff0c;加速海外业务的发展。 然而&#xff0c…

Stable Diffusion教程|图生图原理和实战

Stable Diffusion凭借其卓越的图生图功能&#xff0c;极大地提升了图像生成的可控性与输出品质&#xff0c;赋予用户前所未有的个性化创作风格表达能力。这一革新特性使得Stable Diffusion不仅能精准地捕捉用户的艺术愿景&#xff0c;更能以数字化手段孕育出新颖且极具创意的画…

【Java 8】Lambda: mAA::get 返回函数式接口实例

正文 代码介绍&#xff1a;分别有两个函数式接口Lazy跟LazyDependencyCreator&#xff0c;一个HashMap存储<Object, LazyDependencyCreator>键值对。重点在于mProviders.put(AA.class,mAA::get)&#xff0c;看了很久都没看懂&#xff0c;mAA::get返回的不是mAA本身吗&am…

部署私有YUM源

需将对应版本DVD下载至本机&#xff0c;并保证本机可访问互联网&#xff0c;下载需要的rpm包。 下载DVD并进行挂载 mkdir /data/iso -pmkdir /data/yum -pcd /datawget http://mirrors.aliyun.com/centos/7/isos/x86_64/CentOS-7-x86_64-Everything-1511.isomount -o loop -t…

知识付费app源码快速发布app定制开发一站式定制开发平台,开办技术学校的风险有哪些?如何防范?

现在越来越多的人看好培训行业&#xff0c;投资者们或选择加盟&#xff0c;或选择创业&#xff0c;不管哪一种都是投资&#xff0c;投资就会有风险&#xff0c;那么技术学校在办学过程中&#xff0c;有哪些风险呢? 1、学生人身伤害事故的风险 技术学校的学生&#xff0c;不是同…

java接口介绍

在Java中,接口(interface)是一种特殊的引用类型,它是一种抽象的规范,用于定义一组方法的集合,但不提供方法的具体实现。接口定义了一种契约,规定了类应该具有的方法,但不规定方法的具体实现。一个类可以实现一个或多个接口,从而获得接口中定义的所有方法。 接口在Jav…

npm i 与npm install的区别,接上回的npm ERR! code 128

在admin-element-ui拉取框架代码后&#xff0c;需要先安装依赖&#xff0c;但是会报128的错误&#xff0c;我这里总结一下&#xff0c;接上回一篇博客npm ERR! code 128-CSDN博客后续。 以前一直以为 npm i 与 npm install 是同一个东西&#xff0c;但是就在今天早上安装依赖的…

在input光标处插入内容,并解决TS报错

在input或者textarea的光标处插入内容&#xff0c;如果是键盘输入倒是好说&#xff0c;直接把光标定位过去&#xff0c;键盘打字就可以了&#xff1b;如果在光标处插入内容呢&#xff0c;稍微费点事&#xff0c;倒是不是问题&#xff1b;但ts总是希望把一切弄得规范一些&#x…

Codeforces Round 134 (Div. 1) A. Ice Skating (并查集)

Ice Skating 题面翻译 Description 给出n个点的横纵坐标&#xff0c;两个点互通当且仅当两个点有相同的横坐标或纵坐标&#xff0c;问最少需要加几个点才能使得所有点都两两互通 Input 第一行一个整数n表示点数&#xff0c;之后n行每行两个整数x[ i ]和y[ i ]表示第i个点的…

关于Windows驱动中DPC同步的一些见解说明

DPC会被分配到不停的CPU核心上,如果分配到同一个核心,那么DPC是串行的,如果分配到不同的CPU核心上,那么DPC是并行的,但如果设置WDF_OBJECT_ATTRIBUTES的SynchronizationScope属性为WdfSynchronizationScopeDevice,那么即便CPU有多核,DPC也不会在不同的核心上并发,因为系…

零基础HTML教程(32)--HTML5语义化标签

文章目录 1. div时代2. div的缺点3. 语义化标签4. 语义化标签有哪些5. 实战演练6. 小结 1. div时代 我是2009年开始学习网页开发的&#xff0c;那时候HTML里面到处是div。 这么说吧&#xff0c;那时候div就是网页的骨架&#xff0c;支撑着网页的主结构。 2. div的缺点 div作…

使用J-Link Commander / JFlash 烧写固件程序(以STM32F103C8T6为例)

使用JFlash 烧写流程 运行JFlash, 点击Project Settings 配置Jlink为SWD方式,选择连接设备为STM32F103C8T6, 点击确定. 选择要烧录的Bin文件 设置bin文件烧录地址, 点击OK(地址要在0x08000000-0x0800FFFF范围内) Note : STM32F103C8T6 Flash大小为 64KB&#xff0c; 地址范围…

速盾可以防御的攻击类型是否会随着技术的发展而不断变化?

随着技术的发展&#xff0c;网络攻击的形式也在不断演变。因此&#xff0c;速盾作为一种网络安全防护技术&#xff0c;也需要不断更新和改进&#xff0c;以应对新的攻击类型。本文将从技术发展的角度探讨速盾如何应对不断变化的攻击类型。 首先&#xff0c;随着技术的进步&…

Vuex,在 Vue 组件中监听 Vuex 状态变化,使用watch监听Vuex中的数据

简介&#xff1a;在Vue应用程序中使用Vuex进行状态管理时&#xff0c;经常需要在组件中响应状态的变化。这里来记录一下 一. 在使用 Vuex 进行状态管理时&#xff0c;我们经常需要在组件中响应状态的变化。Vue 提供了两种方式来实现这一点&#xff1a;computed 属性和 watch 选…

重生奇迹mu再生宝石怎么用有什么用

重生奇迹mu再生宝石有2个用处&#xff1a; 1、在玛雅哥布林处给380装备加PVP属性4追4以上的380级装备,守护宝石一颗,再生宝石一颗,成功得到PVP装备,失败宝石消失,装备无变化&#xff1b; 2、给非套装点强化属性用法跟祝福,灵魂,生命一样直接往装备上敲,成功得到随机强化属性一…

八. Django项目之电商购物商城 -- 添加邮箱

Django项目之电商购物商城 – 添加邮箱 一. 用户中心 添加邮箱功能在用户中心中 , 先完善用户中心功能 1. 视图 # 用户中心 class UserInfoCenterView(LoginRequiredMixin,View):def get(self , request):context {username : request.user.username,mobile : request.use…

队列的实现以及队列如何实现栈

一、队列的定义 队列&#xff1a;只允许在一端进行插入数据操作&#xff0c;在另一端进行删除数据操作的特殊线性表&#xff0c;队列具有先进先出 FIFO(First In First Out) 入队列&#xff1a;进行插入操作的一端称为 队尾 出队列&#xff1a;进行删除操作的一端称为 队头 …

20240507 ubuntu20.04+ros noetic 跑通lioslam

任务&#xff1a;跑通lioslam 主要参考博客 IMU激光雷达融合使用LIO-SAM建图学习笔记——详细、长文、多图、全流程_ubuntu_AIDE回归线-GitCode 开源社区 (csdn.net) 1.不要用这一句 wget -O ~/Downloads/gtsam.zip https://github.com/borglab/gtsam/archive/4.0.0-alpha2…

【Spring】初识 Spring AOP(面向切面编程)

目录 1、介绍AOP 1.1、AOP的定义 1.2、AOP的作用 1.3、AOP的核心概念及术语 2、AOP实现示例 3、EnableAspectJAutoProxy注解 1、介绍AOP 1.1、AOP的定义 AOP&#xff08;Aspect Orient Programming&#xff09;&#xff0c;直译过来就是面向切面编程&#xff0c;AOP 是一…