Nginx fast-cgi

3.环境部署
3.1.Nginx的安装、部署与配置
    nginx下载目录 http://nginx.org/en/download.html
    这我们使用的是nginx-1.5.10
    
    [安装]
    下载以后解压并安装(请记得看README
    ./configure (注意了类似checking for *** ... not found项,可能是依赖包没有,则需要安装依赖包)
    
    缺少pcre,则需要额外安装 http://www.pcre.org/ (或者采用apt-get或yum的安装方式)
    缺少zlib,则需要额外安装 http://www.zlib.net/ (或者采用apt-get或yum的安装方式)  
    缺少OpenSSL,则需要额外安装 http://www.openssl.org (或者采用apt-get或yum的安装方式)  
    如果需要配置安装额外的功能模块,可以参考这里 http://wiki.codemongers.com/NginxChsInstall
 
    make
    make install (默认安装到/usr/local/nginx
 
    [配置和管理]     
    1)执行选项
        -c </path/to/config> 为 Nginx 指定一个配置文件,来代替缺省的。不输入则使用默认的配置文件。
        -t 不运行,而仅仅测试配置文件。nginx 将检查配置文件的语法的正确性,并尝试打开配置文件中所引用到的文件。
        -v 显示 nginx 的版本。
        -V 显示 nginx 的版本,编译器版本和配置参数。
 
    2)检查配置文件
        sudo ./nginx -t
        nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
        nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
   
     3)启动 - 默认和特殊
        /usr/local/nginx/sbin/nginx (默认启动方式)
        /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf (指定配置文件启动)
    
    4)查看nginx进程号(master是主进程)
        ps -ef | grep nginx 
 
    5)重新加载配置文件
        sudo kill -HUP [nginx主进程号]
        通过系统的信号控制 Nginx
        可以使用信号系统来控制主进程。默认,nginx 将其主进程的 pid 写入到 /usr/local/nginx/logs/nginx.pid 文件中。通过传递参数        给 ./configure 或使用 pid 指令,来改变该文件的位置。
        
        主进程可以处理以下的信号:
        命令说明 备注
        TERM, INT 快速关闭 
        QUIT 从容关闭 
        HUP 重载配置用新的配置开始新的工作进程    从容关闭旧的工作进程
        USR1 重新打开日志文件 
        USR2 平滑升级可执行程序 
        WINCH 从容关闭工作进程 
 
    6)默认目录结构
        主目录:/usr/local/nginx/
        配置目录:/usr/local/nginx/conf/
        root目录:/usr/local/nginx/html/
        可执行文件路径:/usr/local/nginx/sbin/
 
3.2.spawn_fastcgi的安装、部署与配置
    spawn_fastcgi  https://github.com/lighttpd/spawn-fcgi 
    这里使用的是1.6.3的版本 https://github.com/lighttpd/spawn-fcgi/releases/tag/v1.6.3
    
    下载以后解压并安装(请记得看README)
    如果没有configure,请先执行./autogen.sh,生成configure
    
    ./configure
    make
 
    编译好以后,将可执行文件移动到nginx的sbin目录下
    cp ./src/spawn-fcgi /usr/local/nginx/sbin/ (cp到nginx的安装目录下)
 
3.3.fastcgi库的安装(库绝对不是必须的,觉得技术好的大牛可以自己写)
    库地址 http://www.fastcgi.com/dist/fcgi.tar.gz
    下载以后,解压并安装 (默认安装)
    ./configure
    make
    make install
    
4.Demo和web发布
4.1.Demo程序
    [CGI程序]     
[cpp]  view plain copy
  1. #include <fcgi_stdio.h>  
  2. #include <stdlib.h>  
  3.   
  4. int main() {  
  5.     int count = 0;  
  6.     while (FCGI_Accept() >= 0) {  
  7.         printf("Content-type: text/html\r\n"  
  8.                 "\r\n"  
  9.                 ""  
  10.                 "FastCGI Hello!"  
  11.                 "Request number %d running on host%s "  
  12.                 "Process ID: %d\n", ++count, getenv("SERVER_NAME"), getpid());  
  13.     }  
  14.     return 0;  
  15. }  
    [编译]
    g++ demo.cc -o demo  -lfcgi​  
    
    直接运行可执行文件,看看能否 正常运行。如果出现缺少库libfcgi.so.0,则自己需要手动把/usr/local/lib/libfcgi.so.0库建立一个链接到/usr/lib/目录下:ln -s /usr/local/libfcgi.so.0 /usr/lib/ (或者把so的库路径添加到/etc/ld.so.conf,并执行ldconfig更新一下)
 
4.2.Web发布
    1)将CGI可执行程序移动到nginx的安装目录下 /usr/local/nginx/cgibin (文件夹不存在则自己创建) 
    
    2)启动spawn-fcgi管理进程,并绑定server IP和端口(不要跟nginx的监听端口重合)
     /usr/local/nginx/sbin/spawn-fcgi -a 127.0.0.1 -p 8088 -f /usr/local/nginx/cgibin/demo
    
    查看一下9002端口是否已成功:netstat -na | grep 8088
​   
    3)更改nginx.conf配置文件,让nginx转发请求
    
    在http节点的子节点-"server节"点中下添加配置
    location ~ \.cgi$ {
        fastcgi_pass 127.0.0.1:8088;
        fastcgi_index index.cgi;
        fastcgi_param SCRIPT_FILENAME fcgi$fastcgi_script_name;

        include fastcgi_params;
    }
 
    4)重启nginx或者重新加载配置文件
    重新加载配置文件
    sudo kill -HUP [pid]
    或者
    重启nginx    
    killall nginx
​    ./nginx
 
    5)打开浏览器访问一下吧
    http://localhost/demo.cgi

猜你喜欢

转载自blog.csdn.net/ffhyy/article/details/49995195