python调用接口十几分钟卡死_接口处理请求时间过长,前台响应“服务器超时”的解决办法...

问题场景

数据计算量过大,接口响应时间过长时,网关会报超时,页面就挂了,没有更好的解决办法,暂时采用了一个临时方案,步骤如下:

1.将原本的一个接口拆分为3个,三个接口异步操作。三个接口作用及描述如下:

接口1:获取本地异步操作的唯一标识-唯一且加密后的code值

请求体:此次查询操作的查询条件

返回体:唯一的加密后的唯一code

接口2:轮询此次查询的结果是否已计算并准备好

请求体:接口1返回的code

返回体:-1或0 -----0 数据未计算完成 1-数据已经计算完成并准备好

接口3:查询

请求体:接口1返回的code

返回体:最终的查询结果

2.三个接口的执行顺序:

页面发起查询请求,首先调用接口1,获取code。

code已返回,前端启用定时器,固定间隔调用接口2,直到接口2返回1,停止轮询,调用接口3,拿到返回数据,渲染页面。

前端开始调用接口2时,后端同时执行接口2和3 ,获取查询状态

3.大致代码如下:

pollingFunctions () {

if (this.queryTimer) {

clearInterval(this.queryTimer);

}

let _this = this;

// 接口1-获取唯一标识code

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您发起的 HTTP POST 请求响应时间,您可以使用 `requests` 库的 `Timeout` 参数来设置最大等待时间,并在超时时抛出 `Timeout` 异常。以下是一个示例: ```python import requests url = 'http://example.com' timeout = 5 # 设置超时时间为 5 秒 data = {'key1': 'value1', 'key2': 'value2'} # POST 请求的数据 try: response = requests.post(url, data=data, timeout=timeout) response.raise_for_status() # 检查响应码是否为 200 except requests.exceptions.Timeout: print('请求超时,请稍后重试!') except requests.exceptions.RequestException as e: print('请求发生错误:', e) else: print('请求成功!') print(response.text) ``` 在上面的代码中,我们使用 `requests.post()` 方法发起 POST 请求,并将超时时间设置为 5 秒。如果请求超时,`requests` 库会抛出 `requests.exceptions.Timeout` 异常,并打印出错误信息。如果发生其他类型的异常,则会捕获 `requests.exceptions.RequestException` 异常并打印出错误信息。如果请求成功,则会打印出响应体。 另外,您还可以在发起请求前使用 `socket` 模块设置全局超时时间,以确保所有请求都在规定时间内完成。以下是一个示例: ```python import socket # 设置全局超时时间为 5 秒 socket.setdefaulttimeout(5) ``` 使用此方法时需要注意,全局超时时间会影响所有网络操作,因此可能会影响其他应用程序的网络通信。如果您只想控制某个请求超时时间,建议使用 `requests` 库的 `Timeout` 参数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值