mod_fastcgi和mod_fcgid的区别

mod_fcgid是一个跟mod_fastcgi二进制兼容的Apache module。php


原 来的mod_fastcgi由于实现方式的限制,因此可能会建立了不少没必要要的进程,而实际上只须要更少的进程就能处理一样的请求。 mod_fastcgi的另一个问题是每个CGI的多个进程都共享同一个管道文件,全部到同一个fastcgi的通信都经过这个同名的管道文件进行, 这样当出现通信错误的时候,根本不知道正在通信的是哪个fastcgi,因而也没有办法将这个有问题的进程杀死。数据库


mod_fcgid尝 试使用共享内存来解决这个问题。共享内存里面有当前每一个fastcgi进程的信息(包括进程号,进程使用的管道文件名等),当 每次尝试请求fastcgi工做的时候,Apache将会首先在共享内存里面查询,只有在共享内存里面发现确实没有足够的fastcgi进程了,才会建立 新的进程,这样能够保证当前建立的进程数量恰好可以处理客户的请求。另外,因为每个fastcgi进程使用不一样名称的管道文件,因此能够在通信失败的时 候知道到底哪一个fastcgi进程有问题,而可以尽早的将其剔除。安全


程序实现的目标ide


跟mod_fastcgi二进制兼容
只要在Apache中用mod_fcgid替换了mod_fastcgi,就能工做。原来的fastcgi程序不用从新编译,当即能够工做。测试


更严格的控制进程的建立
Apache中每个request handler都能经过共享内存知道当前系统fastcgi运行的状况,这样能够防止过分的建立fastcgi进程,无谓的消耗系统的资源。spa


简单清晰的进程建立速度控制策略线程

每 一个fastcgi都会维护一个计数器,这个计数器在程序建立和程序结束的时候都会增长,而这个计数器每秒会减1,直到0。当计数器的值高于某个  阀值的时候,程序就会中止建立,直到计数器的值回落。这样既能够保证在请求忽然增多的时候可以快速反应(特别是Apache刚启动,须要大量建立程序的时 候),也能保证当fastcgi程序有问题,不断重起的时候,重起的速度不会太高而消耗过多的系统资源。进程


自动检测出有问题的进程内存

由于每一个fastcgi使用本身特定的管道文件,因此在通信错误的时候能够轻易知道哪个程序出现问题,而尽早的将其剔除。资源


可移植性
遵 照Apache2的习惯,全部可移植的代码都放到一块儿,全部不可移植的代码都在arch目录下分开存放。当前已经测试过的系统包括 Linux ,  FreeBSD(已经包含入FreeBSD4和FreeBSD5的port中), Solaris, Windows 2000.


支持FastCGI方式运行的PHP

可 以直接支持以FastCGI方式运行的PHP。由于PHP如今还不能保证全部的扩展代码都是线程安全的,因此并不建议在Apache2的线程模式  下使用mod_php。而以FastCGI方式运行的PHP则是其中一个解决办法。另外,使用mod_fcgi还能够在不修改任何PHP代码的状况下,获 得数据库链接池的功能,大大减小PHP进程到数据库的链接。

相关文章
相关标签/搜索