1XX代表提示信息
2XX代表成功信息
3XX代表重定向信息
5XX代表服务器错误信息
状态码 含义
100 客户端应当继续发送请求。这个临时响应是用来通知客户端它的部分请求已经被服务器接收,且仍未被拒绝。客户端应当继续发送请求的剩余部分,或者如果请求已经完成,忽略这个响应。服务器必须在请求完成后向客户端发送一个最终响应。
101 服务器已经理解了客户端的请求,并将通过Upgrade 消息头通知客户端采用不同的协议来完成这个请求。在发送完这个响应最后的空行后,服务器将会切换到在Upgrade 消息头中定义的那些协议。 只有在切换新的协议更有好处的时候才应该采取类似措施。例如,切换到新的HTTP 版本比旧版本更有优势,或者切换到一个实时且同步的协议以传送利用此类特性的资源。
102 由WebDAV(RFC 2518)扩展的状态码,代表处理将被继续执行。
200 请求已成功,请求所希望的响应头或数据体将随此响应返回。
201 请求已经被实现,而且有一个新的资源已经依据请求的需要而建立,且其 URI 已经随Location 头信息返回。假如需要的资源无法及时建立的话,应当返回 ‘202 Accepted‘。
202 服务器已接受请求,但尚未处理。正如它可能被拒绝一样,最终该请求可能会也可能不会被执行。在异步操作的场合下,没有比发送这个状态码更方便的做法了。 返回202状态码的响应的目的是允许服务器接受其他过程的请求(例如某个每天只执行一次的基于批处理的操作),而不必让客户端一直保持与服务器的连接直到批处理操作全部完成。在接受请求处理并返回202状态码的响应应当在返回的实体中包含一些指示处理当前状态的信息,以及指向处理状态监视器或状态预测的指针,以便用户能够估计操作是否已经完成。
203 服务器已成功处理了请求,但返回的实体头部元信息不是在原始服务器上有效的确定集合,而是来自本地或者第三方的拷贝。当前的信息可能是原始版本的子集或者超集。例如,包含资源的元数据可能导致原始服务器知道元信息的超级。使用此状态码不是必须的,而且只有在响应不使用此状态码便会返回200 OK的情况下才是合适的。
204 服务器成功处理了请求,但不需要返回任何实体内容,并且希望返回更新了的元信息。响应可能通过实体头部的形式,返回新的或更新后的
HTTP500类型错误码出现的原因以及分析
出现500类型错误问题的时候可以从3个方向来发现问题。
为什么要考虑客户端问题?如果报的错误是501错误,那么有一种可能是客户端的http请求method是nginx无法识别的类型,那么这种情况下会报501错误。
当然,这种情况概率很小,基本不会遇到。
还有一种情况是我们自己为了限制http请求的方法,手动修改nginx配置返回501,这样,当客户端使用我们限定之外的method进行请求时,就会收到501错误码。
配置方法如下:本例中我们只允许GET和HEAD以及POST类型的请求,其他类型将会收到501错误
2.上游
PHP之类的CGI程序出现错误,例如PHP-FPM执行超时,这时nginx会返回502错误,这个502其实是php-fpm间接报给nginx的。接下来的思路就是看PHP-FPM为什么会执行超时,可以继续查看上游
mysql或者redis或者调用的API是否出现了超时,再或者有死循环之类的错误,一一排查后能解决相应错误。
3.nginx本身
如果nginx本身出现问题,例如配置问题,如果NGINX未在自己配置的规定时间内收到上游响应则会报504错误
至于503错误一般是nginx负载过高导致的,对于流量较小的网站来说,也算是一件好事。
505 错误很明显,客户端的http版本不受nginx支持
总结一下,501看客户端 502看上游,504先看nginx本身的配置,然后还得看上游,上游不能太慢啊。503考虑升级服务器或者限流。505别考虑了,基本不会出现。
欢迎分享,转载请注明来源:夏雨云
评论列表(0条)