HTTP状态码(HTTP Status Code)是用以表示网页服务器HTTP响应状态的3位数字代码。它由 RFC 2616 规范定义的 ,并得到RFC 2518、RFC 2817、RFC 2295、RFC 2774、RFC 4918等规范扩展。我们最常见的就是“404”所有状态码的第一个数字代表了响应 的五种状态之一。对于每个状态码如果我们通过修改一些配置来复现它是不是我们更便于深入的理解呢?同时也会便于我们掌握它。
复现环境: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 已经安装并运行成功。(如果配置都没错还是访问不了请检查你的防火墙)
二、安装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();
访问发现并不能正常显示,因为我们没配置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; }
2)、再次进入网页查看
http://localhost/hello.php
三、模拟状态码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、打开浏览器测试一下
显示正常,因为web目录什么都没有所以显示403。
4、现在Nginx是代理着自己的一个81端口正如我们开头所说的Nginx现在就是一个网关现在我们把“网关”断开看看会出现什么情况。
5、如图所示我们把监听端口随便改一个,上面我们配置文件里代理的是自己机器的81端口现在81端口不在了。我们通过下面的日志可以看到返回了大量的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日志。
最后总结一下:
- 499是由于超过客户端设置的请求超时时间,客户端主动关闭连接。
- 502是由于CGI由于在自身的执行时间要求内无法按时完成,则无法返回给服务器正常 响应。