当前位置: 首页 > news >正文

常见Http错误码学习

常见 http 错误码

服务器巡检时比较常见的 http 错误码

  • 400 Bad Request
  • 408 Request Timeout
  • 499 client has closed connection
  • 502 Bad Gateway
  • 504 Gateway Timeout
    这些错误码反映了服务器什么样的状态,仅看字面意思还不太容易理解,就动手做个试验吧

试验环境

在 linux 主机上运行 nginx,在本机(windows 10)上运行 jetty,linux 上的 nginx 反向代理到本机 jetty

试验工具

发送 http 请求主要采用 postman,也使用了 telnet 和 python 脚本

试验

400

错误的请求,比如必须的参数未传递,那么我们来试下

@Controller
@RequestMapping("/api/")
public class TestController {@ResponseBody@RequestMapping("test.debug")public String test(@RequestParam(required = true) String name) {return name;}}

可以看到 name 参数是必须的,那么不带参数调用一下

http://xxxxx.in.xxxx.com/api/test.debug

返回 200.

怎么返回了 200 而不是预期的 400呢?经过一番检查,原来是有个异常处理程序捕捉到了参数未传递的异常并进行了处理,如下

@Component
public class ExceptionHandler implements HandlerExceptionResolver {private static final Logger log = Logger.getLogger(ExceptionHandler.class);@Overridepublic ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response,Object handler, Exception ex) {response.setContentType("application/json; charset=UTF-8");String code = null;String message = null;if (ex instanceof BizException) {BizException exception = (BizException) ex;message = exception.getMessage();code = Integer.toString(exception.getErrorCode());} else if (ex instanceof MissingServletRequestParameterException) {code = "900002";message = ex.getMessage();log.error(message);} else {code = "403";message = ex.getMessage();log.error(ex, ex);}ModelAndView mav = new ModelAndView("error");mav.addObject("code", code);mav.addObject("message", message);mav.addObject("value", message);return mav;}}

禁用该异常处理以后,重新试验返回了 400,如下

此外,胡乱的发送数据给 nginx 服务器而不按 http 协议规范组织数据,也会得到 400 的返回码,可以用 telnet 试验一下,如下图

在用 telnet 给 nginx 发送数据时,输入 “HTTP/2.3.”,由于 2.3. 是不存在的版本,nginx 当即返回了 400 错误码

408

请求超时,nginx 在规定的时间内无法获取到客户端的请求
这个错误码很奇怪,根据该错误码的含义,使用 telnet 和 python 进行模拟,但无法使 nginx 返回 408 错误码…试验失败了
另外,查看 nginx 日志,发现返回 408 错误码的日志,实际上请求都已经转发给 jetty 并且 jetty 也返回了 200 响应码.

所以,这个错误码目前还无法解释

499

在 nginx 返回结果之前,客户端断开了连接,nginx 会记录 499 错误码到日志,要重现这个错误码,只需要让接口等待一段比较长的时间,并在请求端主动断开即可,如下

@Controller
@RequestMapping("/api/")
public class TestController {@ResponseBody@RequestMapping("test.debug")public String test(@RequestParam(required = true) String name) {try {Thread.sleep(300 * 1000);} catch (InterruptedException e) {}return name;}
}

在 postman 里发起请求,并在等待的过程中点击 cancel 按钮

这时 postman 没有任何返回,但是查看 nginx 的日志,会发现一条 499 的记录,如下

502

这个比较好理解,jetty 服务挂了或者没有启动,我们停掉 jetty 就可以得到这个错误码.

504

这是 jetty 响应超时了,我们让接口等待 300 秒后返回,来测试一下

@Controller
@RequestMapping("/api/")
public class TestController {@ResponseBody@RequestMapping("test.debug")public String test(@RequestParam(required = true) String name) {try {Thread.sleep(300 * 1000);} catch (InterruptedException e) {}return name;}
}

可以看到在60秒(准确的说,60133 ms)以后,nginx 返回了 504

这是因为 nginx 默认等待 jetty 60 秒,时间到了 jetty 没有响应 nginx 就会自行返回 504;如果想要 nginx 多等一段时间,可以如下配置

proxy_read_timeout 6m; 

现在再试一下

可以看到,经过 300 秒(300062 ms)的漫长等待,我们得到了 jetty 的响应

结论

  • 400 客户端请求数据格式不对,不符合接口规范.和客户端沟通,要求客户端修复.服务端进行容错处理

  • 408不知道.继续研究

  • 499 由于服务器处理太慢,客户端在规定的时间内未接收到响应,主动断开连接.客户端网络被断开了,在移动互联网环境下这还是比较常见的,例如用户移动到 WIFI 覆盖区域以外/服务端优化性能

  • 502 服务器宕机, 重启服务器

  • 504 服务端响应太慢了, 优化性能

http://www.lryc.cn/news/66822.html

相关文章:

  • qemu-基础篇——ARM 链接过程分析(六)
  • Java企业工程项目管理系统+spring cloud 系统管理+java 系统设置+二次开发
  • Eureka与Zookeeper的区别
  • 顺序表和链表的各种代码实现
  • C# 介绍三种不同组件创建PDF文档的方式
  • 极简面试题 --- Redis
  • 可视化图表API格式要求有哪些?Sugar BI详细代码示例(4)
  • 学习vue(可与知乎合并)
  • 【UEFI实战】Linux下如何解析ACPI表
  • Java-Redis持久化之RDB操作
  • 信号signal编程测试
  • Linux学习记录——이십삼 进程信号(2)
  • Revit中如何创建曲面嵌板及一键成板
  • STM32F4_DHT11数字温湿度传感器
  • WiFi(Wireless Fidelity)基础(十一)
  • 操作系统—— 精髓与设计原理--期末复习
  • 每天一道算法练习题--Day21 第一章 --算法专题 --- ----------位运算
  • D1. LuoTianyi and the Floating Islands (Easy Version)(树形dp)
  • rk3588移植ubuntu server
  • 如何更好地刷力扣
  • 上采样和下采样
  • 小猪,信息论与我们的生活
  • 【鸿蒙应用ArkTS开发系列】- http网络库使用讲解和封装
  • 【Java零基础入门篇】第 ⑥ 期 - 异常处理
  • 计算职工工资
  • 2019年上半年软件设计师下午试题
  • IS200TPROH1BCB用于工业应用和电力分配等。高压型隔离开关用于变电站
  • 【MySql】数据库 select 进阶
  • CVPR 2023 | VoxelNeXt实现全稀疏3D检测跟踪,还能结合Seg Anything
  • 本地使用3台centos7虚拟机搭建K8S集群教程