最近,因为工作的需要,我们用Nginx+FastCGI部署了一个高性能的Web服务器。在部署的过程中,我们遇到了很多问题,也参考了一些文章,发现很少有文章将整个编译部署的过程讲清楚的。鉴于此,根据我们项目组成功部署Nginx+FastCGI的经验,我写下了这篇文章,可供相关项目的开发人员参考。

首先,对于为什么要用Nginx+FastCGI部署高性能Web服务器,我就不赘述了,网上有很多的文章

下面详细介绍编译部署的过程。

1.软件准备
(1)Linux机器
所有的程序都是部署在Linux操作系统上面的,因此建议要有一台专门的机器来安装Linux。我们使用的Linux是CentOS 7,大家可根据项目组的实际情况来选择Linux的版本。

(2)Nginx源码包
到Nginx的官网(​​​http://nginx.org/en/download.html​​)上去下载最新的源码包,我们使用的是nginx-1.11.9.tar.gz。

(3)spawn_fastcgi源码包
到网站​​​https://github.com/lighttpd/spawn-fcgi/releases​​ 上去下载源码包spawn-fcgi-1.6.4.tar.gz。

(4)FastCGI源码包
在百度上搜索并下载源码包fcgi-2.4.1-SNAP-0910052249.tar.gz,也可到该网站上去下载:​​​http://www.filewatcher.com/d/Gentoo/distfiles/Other/fcgi-2.4.1-SNAP-0910052249.tar.gz.614929.html​​。

2.编译安装
1)编译安装Nginx
第一步,执行tar zxvf nginx-1.11.9.tar.gz 命令解压文件到当前目录下(具体的安装包名根据你下载的Nginx包进行确定)。
第二步,进入解压后的nginx-1.11.9目录执行./configure –prefix=/usr/local/nginx命令。
第三步,执行make命令。
第四步,执行make install命令。

2)编译安装spawn_fastcgi
第一步,执行tar zxvf spawn-fcgi-1.6.4.tar.gz 命令解压文件到当前目录下。
第二步,进入spawn-fcgi-1.6.4目录执行./configure命令。
第三步,执行make命令。
第四部,将文件spawn-fcgi拷贝到/usr/local/nginx/sbin目录下(拷贝之前如果没有这个目录,请手动创建)。

3)编译安装FastCGI
第一步,执行tar jxvf fcgi-2.4.1-SNAP-0910052249.tar.gz 命令解压文件到当前目录下。
第二步,进入fcgi-2.4.1-SNAP-0910052249目录执行./configure命令。
第三步,执行make命令。
第四步,执行make install命令。

3.测试程序编写及编译
我们编写了如下的测试程序test.c,代码如下:

#include <stdio.h>
#include <fcgi_stdio.h>
#include <stdlib.h>

int main()
{
int count = 0;
while (FCGI_Accept() >= 0)
{
printf("Content-type: text/html\r\n"
"\r\n"
""
"FastCGI Hello!"
"Request number %d running on host%s
"Process ID: %d\n", ++count, getenv("SERVER_NAME"), getpid());
}
return 0;
}

使用“gcc -g -o test test.c -lfcgi”命令编译生成可执行文件test,然后将test拷贝到/usr/local/nginx/sbin目录下。

4.Nginx配置
在/usr/local/nginx/conf/nginx.conf配置文件中的http节点的server子节点下添加如下配置:

location ~ /test.cgi$ {
fastcgi_pass 127.0.0.1:8088;
fastcgi_index index.cgi;
fastcgi_param SCRIPT_FILENAME fcgi$fastcgi_script_name;

include

5.服务端启动
(1)启动Nginx服务器
执行/usr/local/nginx/sbin/nginx命令启动Nginx。

说明:
1)可用ps -ef | grep nginx命令查看Nginx启动是否成功,正常情况下为两个进程(一个主进程一个辅进程),示例如下:

# ps -ef | grep nginx
root 2886 1 0 May15 ? 00:00:00 nginx: master process ./nginx
nobody 3406 2886 0 May15 ? 00:00:00 nginx: worker process

2)可用“kill -HUP 主进程id ”命令(如:kill -HUP 1)重新加载配置文件。

3)可用“kill -QUIT 主进程id” 命令(如:kill -QUIT 1)关闭Nginx。

(2)启动spawn-fcgi管理进程
执行“/usr/local/nginx/sbin/spawn-fcgi -a 127.0.0.1 -p 8088 -f /usr/local/nginx/sbin/test”命令启动进程。

说明:
1)可用“netstat -an|grep 8088”命令检查8088端口是否启动监听。

2)可用“ps -ef|grep test”命令检查test进程是否启动成功。

6.使用Web前端访问test
在浏览器中输入URL地址“​​​http://127.0.0.1/test.cgi​​”即可访问到test的输出。