首页 技术 正文
技术 2022年11月20日
0 收藏 665 点赞 4,850 浏览 2613 个字

以lighttpd fastcgi写一下自己对fastcgi分布式的理解。

假设一台机器A上运行lighttpd,在这台主机上只是对请求进行分发。

而在其他多台机器上运行多个fastcgi进程,用来接收来自机器A分发过来的请求,并进行处理。

那lighttpd的配置fastcgi部分,应该配置ip和port(配置socket时是针对lighttpd和fastcgi进程在同一台机器上)。

而fastcgi进程应该监听ip:port上的请求。

稍微修改下前面的配置文件和代码。

server.document-root = “/mnt/hgfs/share/test/fcgi/”
server.port = 9090
socket_dir = “/tmp/”
server.username = “weifeilong” 
server.groupname = “weifeilong” 
server.errorlog = “/mnt/hgfs/share/test/fcgi/err.log”
mimetype.assign = (
“.html” => “text/html”, 
“.txt” => “text/plain”,
“.jpg” => “image/jpeg”,
“.png” => “image/png” 
)

static-file.exclude-extensions = ( “.fcgi”, “.php”, “.rb”, “~”, “.inc” )
index-file.names = ( “index.html” )
server.modules += (“mod_fastcgi”)
fastcgi.server = (
   ”/fellow” => (
    ”test.fastcgi.handler” => (
    ”host” => “127.0.0.1”//对于多台机器的,可以为其他运行fastcgi进程的ip

    ”port” => “9090”    

#”socket” => socket_dir + “test.fastcgi.socket”,
    ”check-local” => “disable”,
    #”bin-path” => “/mnt/hgfs/share/test/fcgi/test.fastcgi”,
    ”max-procs” => 10,
    )
  )
)

fastcgi进程:

#include <stdlib.h>
#include <string.h>
#include <syslog.h>
#include <alloca.h>
#include <fcgiapp.h>
#include <stdio.h>
#define LISTENSOCK_FILENO 0
#define LISTENSOCK_FLAGS 0
int main(int argc, char** argv) {
  openlog(“testfastcgi”, LOG_CONS|LOG_NDELAY, LOG_USER);
  int err = FCGX_Init(); /* call before Accept in multithreaded apps */
  if (err) { syslog (LOG_INFO, “FCGX_Init failed: %d”, err); return 1; }
  FCGX_Request cgi;

  int sock = FCGX_OpenSocket(“127.0.0.1:9090”, 10);//在127.0.0.1:9090上监听。
  err = FCGX_InitRequest(&cgi, sock, LISTENSOCK_FLAGS);
  if (err) { syslog(LOG_INFO, “FCGX_InitRequest failed: %d”, err); return 2; }

  while (1) {
    err = FCGX_Accept_r(&cgi);
    if (err) { syslog(LOG_INFO, “FCGX_Accept_r stopped: %d”, err); break; }

    #if 1
    char* header = (char*) alloca(200);
    strcpy(header, “Status: 200 OK\r\nContent-Type: text/html\r\n\r\n”);
    FCGX_PutStr(header, strlen(header), cgi.out);
    char response[1024];
    if(!strncmp(“GET”, FCGX_GetParam(“REQUEST_METHOD”, cgi.envp), strlen(“GET”)))
    {
      FCGX_PutStr(“GET”, strlen(“GET”), cgi.err);
      if(!strncmp(“action=getInfo”, FCGX_GetParam(“QUERY_STRING”, cgi.envp), strlen(“action=getInfo”)))
      {
        snprintf(response, sizeof(response), “{\”action\”: \”getInfo\”}\n”);
      }
    }
    else if(!strncmp(“POST”, FCGX_GetParam(“REQUEST_METHOD”, cgi.envp), strlen(“POST”)))
    {
      char *post_data = (char*)malloc(1024);
      FCGX_GetStr(post_data, 1024, cgi.in);
      FCGX_PutStr(post_data, 1024, cgi.err);
      if(!strncmp(“action=resetInfo”, post_data, strlen(“action=resetInfo”)))
      {
        snprintf(response, sizeof(response), “{\”action\”: \”resetInfo\”}\n”);
      }
    }
    FCGX_PutStr(response, strlen(response), cgi.out);
    #endif
  }
  return 0;
}

先运行fastcgi程序,然后启动lighttpd。

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,031
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,520
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,368
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,148
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,781
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,861