CGI及FastCGI介绍

CGI(Common Gateway Interface)公共网关接口,是HTTP服务器与其他程序通信的工具。FastCGI是一个long-live型的CGI,支持分布式计算,它将CGI解释器进程保持在内存中并因此获得较高的性能。

FastCGI工作方式是接受Web服务器的请求,以HTTP Request的方式进行响应,实现了应用程序与Web服务器的分离。它的使用需要在Web服务器中安装支持组件,目前支持Apache、Nginx、IIS、Lighttpd等。

CGI及FastCGI介绍_第1张图片

优点有:

  • 稳定性,fastcgi是以独立的进程池运行来cgi,单独一个进程死掉,系统可以很轻易的丢弃,然后重新分配新的进程来运行逻辑
  • 安全性,fastcgi和宿主的server完全独立,fastcgi怎么down也不会把server搞垮
  • 性能, fastcgi把动态逻辑的处理从server中分离出来, 大负荷的IO处理还是留给宿主server, 这样宿主server可以一心一意作IO,对于一个普通的动态网页来说,,逻辑处理可能只有一小部分,大量的图片等静态IO处理完全不需要逻辑程序的参与
  • 扩展性,fastcgi是一个中立的技术标准,完全可以支持任何语言写的处理程序(php、java、python、C++)

FastCGI编程包括四部分:初始化编码、接收请求循环、响应内容、响应结束循环。

[cpp]  view plain copy
  1. FCGX_Request request;  
  2. FCGX_Init();  
  3. int sock_fd = FCGX_OpenSocket("10.3.17.75:8003",100);  
  4. FCGX_InitRequest(&request, sock_fd, 0);  
  5. while (FCGX_Accept_r(&request) >= 0) {  
  6.   //get param 1  
  7.   map<string,string> param_map;  
  8.   for(int i = 0; request.envp[i]; ++i) {  
  9.     string s = request.envp[i];  
  10.     size_t pos = s.find_first_of('=');  
  11.     if (pos > 0 && pos < s.size() - 1) {  
  12.       param_map.insert(make_pair(s.substr(0,pos), s.substr(pos+1)));  
  13.     }  
  14.   }  
  15.   //or 2   
  16.   char * clenstr = FCGX_GetParam("CONTENT_LENGTH", request.envp);  
  17.   //do something  
  18.   FCGX_Stream* fcgi_out = request.out;  
  19.   string output="test";  
  20.   FCGX_PutS(output.c_str(), fcgi_out);  
  21.   //finish  
  22.   FCGX_Finish_r(&request);  
  23. }  

你可能感兴趣的:(CGI及FastCGI介绍)