502状态码_一边制造,一边讲解HTTP状态码502|499

HTTP状态码(HTTP Status Code)是用以表示网页服务器HTTP响应状态的3位数字代码。它由 RFC 2616 规范定义的 ,并得到RFC 2518、RFC 2817、RFC 2295、RFC 2774、RFC 4918等规范扩展。我们最常见的就是“404”所有状态码的第一个数字代表了响应 的五种状态之一。对于每个状态码如果我们通过修改一些配置来复现它是不是我们更便于深入的理解呢?同时也会便于我们掌握它。

f3790d06789d4d799d5453b68f2e519a

not found

复现环境:Centos7、Nginx、php-fpm

一、首先安装Nginx。

1.gcc

nginx是C语言开发,建议在linux上运行。

安装nginx需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc。

yum install -y gcc-c++

2.PCRE

PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。

yum install -y pcre pcre-devel

3.zlib

zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。

yum install -y zlib zlib-devel

4、下载Nginx

wget http://nginx.org/download/nginx-1.8.0.tar.gz

5、解压

tar -zxvf nginx-1.8.0.tar.gz

6、配置参数

./configure --prefix=/usr/local/nginx --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --with-http_gzip_static_module --http-client-body-temp-path=/var/temp/nginx/client --http-proxy-temp-path=/var/temp/nginx/proxy --http-fastcgi-temp-path=/var/temp/nginx/fastcgi --http-uwsgi-temp-path=/var/temp/nginx/uwsgi --http-scgi-temp-path=/var/temp/nginx/scgi

7、make

make && make install

8、启动

/usr/local/nginx/sbin/nginx

9、打开浏览器访问此机器的 IP,如果浏览器出现 Welcome to nginx! 则表示 Nginx 已经安装并运行成功。(如果配置都没错还是访问不了请检查你的防火墙)

10e2a346e2fd4114aa590c58c2a60552

出现如上画面则表示安装成功

二、安装php-fpm

1、安装epel-release

通过命令:

yum -y install epel-release

2、安装PHP7

终端再次运行如下命令:

rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpmrpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

3、yum查看

yum search php70w-fpm #PHP7.0yum search php71w-fpm #PHP7.1yum search php72w-fpm #PHP7.2

4、安装PHP 7.0、7.1的yum源,然后再执行:

安装php 7.0以及扩展:yum install php70w php70w-fpm php70w-cli php70w-common php70w-devel php70w-gd php70w-pdo php70w-mysql php70w-mbstring php70w-bcmath php70w-xml php70w-pecl-redis php70w-process php70w-intl php70w-xmlrpc php70w-soap php70w-ldap php70w-opcache安装php 7.1以及扩展:yum install php71w php71w-fpm php71w-cli php71w-common php71w-devel php71w-gd php71w-pdo php71w-mysql php71w-mbstring php71w-bcmath php71w-xml php71w-pecl-redis php71w-process php71w-intl php71w-xmlrpc php71w-soap php71w-ldap php71w-opcache安装php 7.2以及扩展:yum install -y php72w php72w-fpm php72w-cli php72w-common php72w-devel php72w-gd php72w-pdo php72w-mysql php72w-mbstring php72w-bcmath php72w-xml php72w-pecl-redis php72w-process php72w-intl php72w-xmlrpc php72w-soap php72w-ldap php72w-opcache

5、开启服务

systemctl start php-fpm

6、开机开启服务

systemctl enable php-fpm

7、写一个PHP脚本hello.php放到服务器web根目录下:

<?php phpinfo();
3e6262397bba44d78738b250e0c0d2b8

访问发现并不能正常显示

访问发现并不能正常显示,因为我们没配置Nginx解析php页面,接下来就去配置一下

1)、在Nginx主配置文件中http模块中插入下列内容

 location ~ .php$ { root html; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name; include fastcgi_params; }
40100c14465b49758775157d63025a17

插入内容如图

2)、再次进入网页查看

http://localhost/hello.php
964e4a4e510f4f25882ddab6ea5478ea

出现以上画面表示可以正常访问

三、模拟状态码502

502定义

502,Bad Gateway,网关错误,它往往表示网关从上游服务器中接收到的响应是无效的。先来了解一下网关是什么含义,从宏观定义上来说只要连接两个不同的网络的设备都可以叫网关,其实具体到应用层Http请求这一领域,网关就是指是转发其他服务器通信数据的服务器,对于本文的复现环境而言,当客户端请求数据到达nginx,nginx负责把请求转交给其它的代理的网站客户端(如tomcat、php-fpm等)进行处理,那么在这个场景中Nginx就是网关。

1、这里为了更容易操作一些呢我就让Nginx代理自己的一个其他端口,首先去修改Nginx配置文件。

vi /usr/local/nginx/conf/nginx.conf

2、我们在Nginx配置文件http模块里面添加Nginx反向代理自己的一个端口。

 location / { proxy_pass http://localhost:81; #root html; #index index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } location ~ .php$ { root html; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name; include fastcgi_params; }} server { listen 81; server_name localhost; #charset koi8-r; access_log logs/81.log main; location / { root html; index index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; }}

3、打开浏览器测试一下

1461610c61504e5995432615cfc3a44e

因为web目录什么都没有所以显示403

显示正常,因为web目录什么都没有所以显示403。

4、现在Nginx是代理着自己的一个81端口正如我们开头所说的Nginx现在就是一个网关现在我们把“网关”断开看看会出现什么情况。

15e77e3d183e421c913b9c6d95a69516

如图所示

5、如图所示我们把监听端口随便改一个,上面我们配置文件里代理的是自己机器的81端口现在81端口不在了。我们通过下面的日志可以看到返回了大量的502。

82e7f347e6894180aabfe1bc35fdf062

502

四、模拟状态码499

499定义

499, Client Closed Request, 客户端主动断开连接。是指一次http请求在客户端指定的时间内没有返回响应,此时,客户端会主动断开连接,此时表象为客户端无响应返回,而nginx的日志中会status code 为499。此状态码在浏览器请求时几乎不可见,因为浏览器默认的超时时间会很长。多见于服务之间的调用,在业务架构中常常会分层设计,拆分为不同的子系统或者微服务,这样系统之间就会常常通过http方式来请求,并且会设置每次请求的超时时间,当请求在请求时间内所调用的上游服务无返回,则会主动关闭连接,上游服务日志中会记录一条499。

1、前面我们已经安装完成php-fpm的安装以及Nginx解析php问题所以我们返回码449的实现就相对简单一些。首先呢我们在web目录里写一个php网页,php代码里我们调用了sleep函数就是让网页延迟7秒执行。

<?phpsleep (7);echo'hello world';?>

2、我们用浏览器打开我们的php网页,稍等一会就会出来hello,但是在这个过程中我们关闭这个连接。断开之后我们查看以下Ngixn日志。

34c39c35a10f48e5baf169f4c79f37a6

499

最后总结一下:

  • 499是由于超过客户端设置的请求超时时间,客户端主动关闭连接。
  • 502是由于CGI由于在自身的执行时间要求内无法按时完成,则无法返回给服务器正常 响应。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值