前言:某些目标初始化开销较大,例如从磁盘读取一个大文件,并关联到目标,可能耗时较久.在CGI环境下,每个请求都要new()一次目标,就会性能低下.而mod_perl的多进程预创建目标模式,可以很好的解决这个问题.
(一)安装mod_perl
这里使用主流的apache2.0和modperl2版本.
默认安装的Apache2都支持DSO方式加载第三方模块,在编译modperl2时只须指定对应的apxs即可.
另外Perl对线程的支持一直有问题,因此Apache2在编译时最好指定以prefork方式运行(--with-mpm=prefork).
从http://perl.apache.org/download/下载modperl,解开后进入其目录,如下安装:
perl Makefile.PL MP_APXS=/path/apache2/bin/apxs
make
make test
make install
这里假设apache2.0已安装在/path/apache2下.检查/path/apache2/conf/httpd.conf,确认modperl安装后添加了该行:
LoadModule perl_module modules/mod_perl.so
表示Apache启动时加载mod_perl模块.
(二)安装Apache2::Request
Apache2::Request是包含modperl2下的请求处理方式的类库.它的作用类似于CGI.pm,但用C语言写成,比CGI.pm快很多.
以root用户运行CPAN shell: perl -MCPAN -e shell
然后在CPAN shell里输入: install Apache2::Request 进行安装.安装过程中一般会有提示,须手工指定apache2的apxs文件的路径.如果在make test时不成功,那么force install即可:
cpan>look Apache2::Request
# install Apache2::Request
安装完后修改apache2的httpd.conf,增加一行如下:
LoadModule apreq_module modules/mod_apreq2.so
表示Apache启动时加载mod_apreq2模块.
另外,设置LD_LIBRARY_PATH环境变量,对Linux系统,最简单的做法是在/etc/ld.so.conf里加进:
/usr/local/lib #默认make install的libapreq2安装在/usr/local下
/path/apache2/lib #apache2安装目录
然后执行ldconfig使其生效.
最后restart apache,查看error_log,若有如下提示:
Apache/2.0.59 (Unix) mod_apreq2-20051231/2.6.0 mod_perl/2.0.3 Perl/v5.8.5 configured
则表示modperl2和Apache2::Request已安装成功(当然httpd.conf里的ServerTokens须设置为Full).
(三)开始编程之前
在开始modperl编码之前,需要做一些基本的配置工作.
首先在/path/apache2下创建一个子目录,该目录用于存放自己编写的modperl库文件,并且将该目录添加进modperl运行环境的@INC变量.这个变量包含了modperl需要引用的库路径.
mkdir /path/apache2/run
这里假设创建的子目录名为run.将run添加进modperl的@INC有好几种方法,一般的做法是写进modperl的启动配置文件(通常名为startup.pl).startup.pl还会预加载一些modperl常用类库,这些类库会被多个Apache子进程共享,避免启动后的重复加载.
在run子目录下,创建startup.pl,内容如下:
use strict;
use lib qw(/path/apache2/run);
use Apache2::RequestRec ();
use Apache2::RequestIO ();
use Apache2::Request ();
1;
use lib这一行即将run子目录添加进modperl运行环境的@INC中.
其他三个Apache2::*库是modperl2常用的几个类库.Apache2::*名字空间下有很多类库,除上述外,还有:
Apache2::Connection ();
Apache2::RequestUtil ();
Apache2::ServerUtil ();
Apache2::ServerRec ();
Apache2:og ();
之类...详情可参考它们在cpan上的文档.
不要忘记最后的那个1,它表示返回一个真值给调用者.
修改httpd.conf,增加一行:
PerlPostConfigRequire /path/apache2/run/startup.pl
表示在Apache启动过程中,(尽可能晚的)执行上述modperl配置脚本.
补充一点,在手工运行modperl脚本时,由于@INC不包含这个目录,就会造成问题.可以在运行脚本前,
export PERL5LIB=/path/apache2/run
来解决问题.但每次都敲这个命令也很烦,因此直接将这句写进/etc/profile,就一劳永逸了.
(四)创建一个目标
从CPAN下载安装本人所写的IP::ChinaISP模块,该模块的作用是对指定的中国IP,返回对应的ISP.因为在中国,不同ISP之间的互联互通非常慢,所以利用该模块,可实现一些基于用户访问IP的CDN系统.
模块使用方法很简单:
use IP::ChinaISP;
my $cnisp = IP::ChinaISP->new;
my $isp = $cnisp->ip_isp('12.34.56.78');
$isp变量即存储了12.34.56.78这个IP对应的ISP(如果有的话).
IP::ChinaISP->new表示创建一个对象,这个过程中,会解析IP-ISP的数据文件,并将数据绑定到对象,因此耗时较久.测试了1000次new()过程,平均每次创建对象耗时16.103毫秒.若用该模块提供CGI web服务,则每个用户请求都会创建一个对象,效率无疑低下.
下面描述如何利用modperl来提高效率.
(五)mod_perl的多进程预创建目标
在mod_perl环境下,Apache启动时可以预创建目标,并且该目标在Apache fork子进程时,被所有子进程复制一份.这样在每个子进程里,直接使用已创建好的目标,不用重复创建.
前面已经描述,可以在startup.pl里预加载类库,同样也可以在这个文件里预创建目标.但是,简单在startup.pl里写:
use IP::ChinaISP;
our $cnisp = IP::ChinaISP->new;
不行.由于没有独立的包空间,从外部无法访问这个对象.
因此,有必要把创建目标的陈述放在独立的package里.前面已经定义好/path/apache2/run为modperl运行的库目录,在该目录下创建package即可.如下执行:
cd /path/apache2/run
mkdir IP
cd IP
vi Initdb.pm
Initdb.pm即为初始化目标的package,内容如下:
package IP::Initdb;
use strict;
use IP::ChinaISP;
our $cnisp = IP::ChinaISP->new;
sub initdb { $cnisp }
1;
这里的our $cnisp = IP::ChinaISP->new;即表示创建IP::ChinaISP对象,并将其储藏在包变量$cnisp里.然后在外部可以直接通过包变量来访问这个对象,或通过方法initdb来返回对象.
修改startup.pl,加进一句:
use IP::Initdb;
这样在Apache启动时,对象就被创建好,并复制到所有Apache子进程.
(六)如何使用预创建目标
可以在自定义的Apache处理器里,使用上述对象.假设对目标站点的/iploc路径的请求,都由自己的Apache handler来处理,则如下做.
修改httpd.conf,加进如下配置:
<Location /iploc>
SetHandler modperl
PerlResponseHandler IP:uery
</Location>
IP:uery即是一个modperl处理器,它同样位于前面定义好的库目录/path/apache2/run下.
进入/path/apache2/run/IP,创建Query.pm,内容如下:
package IP:uery;
use strict;
use Apache2::RequestRec ();
use Apache2::RequestIO ();
use Apache2::Const -compile => qw(OK);
use Apache2::Request ();
use IP::Initdb;
sub handler {
my $r = shift;
my $req = Apache2::Request->new($r);
my $ip = $req->param('ip');
my $cnisp = IP::Initdb->initdb;
my $isp = $cnisp->ip_isp($ip);
$r->content_type('text/plain');
$r->print($isp);
return Apache2::Const::OK;
}
1;
my $cnisp = IP::Initdb->initdb;表示获取预创建目标.my $isp = $cnisp->ip_isp($ip);表示调用目标方法,根据IP取得ISP.
配置好上述所有后,restart Apache.然后从浏览器发布请求,例如:
http://example.com/iploc/?ip=202.96.128.68
可看到返回结果.
该WEB服务效率极高,用Apache自带的压力测试工具ab进行测试,共发起100个请求,并发10个,全部处理完只用了0.125秒.测试结果摘录如下:
Document Path: /iploc/?ip=202.96.128.68
Document Length: 11 bytes
Concurrency Level: 10
Time taken for tests: 0.125 seconds
Complete requests: 100
Failed requests: 0
Broken pipe errors: 0
Total transferred: 19500 bytes
HTML transferred: 1100 bytes
Requests per second: 800.00 [#/sec] (mean)
Time per request: 12.50 [ms] (mean)
Time per request: 1.25 [ms] (mean, across all concurrent requests)
Transfer rate: 156.00 [Kbytes/sec] received
分享到:
相关推荐
6. **持续执行的Perl环境**:mod_perl创建了一个持久的Perl运行环境,使得Perl代码可以在多个请求之间保持状态,这对于开发需要保持会话和数据库连接的应用非常有利。 7. **模块化开发**:mod_perl支持使用Perl模块...
标题中的"mod_perl-2.0-current.tar.gz"是一个开源软件包的名称,它代表了mod_perl的2.0版本的一个当前开发版本。mod_perl是Apache HTTP服务器的一个模块,它允许Perl语言深入集成到服务器内部,极大地提高了处理...
- 脚本运行计数器可能超过5是因为Apache服务器在处理请求时可能会创建多个子进程。每个子进程都可能运行同一个Perl脚本,导致脚本的执行次数看起来超过了预期。 ##### 2. **第二个秘密:在reload时无规律的增长**...
4. **安装mod_wsgi**:mod_wsgi的Windows安装通常涉及下载预编译的`.dll`文件和`.pyd`文件,将其放入Apache的`modules`目录。确保mod_wsgi的版本与Apache和Python版本相匹配。配置Apache的`httpd.conf`文件,加载mod...
与传统的CGI相比,FastCGI可以保持多个进程常驻内存,处理连续的HTTP请求,大大减少了进程创建和销毁的时间开销,提高了服务器的响应速度和效率。 **`mod_fcgid`的功能特性** 1. **进程管理**:`mod_fcgid`能够...
在FastCGI中,进程管理器会预启动多个CGI进程,然后持久化地为多个请求服务,提高了处理效率。 mod_fcgid-2.3.9是这个模块的一个版本,发布于某个时间点,可能包含了一些新的特性和改进。通常,软件版本升级会修复...
通过将Perl嵌入到Apache中,mod_perl能够缓存Perl解析器和编译后的代码,减少了每次请求时的初始化时间。 Perl-www-easy结合mod_perl,使得开发者可以直接在服务器端编写Perl代码来处理HTTP请求,提高了响应速度和...
9. **性能优化**:使用 daemon 模式可以提高 mod_wsgi 的性能,因为它可以管理多个独立的 Python 进程,并且可以在不影响其他应用的情况下重启有问题的进程。 10. **错误排查**:在遇到问题时,可以通过查看 Apache...
它允许开发者通过安装各种模块来扩展其功能,如mod_php、mod_perl以及我们讨论的mod_python。 **Python语言** Python是一种高级编程语言,以其简洁的语法和丰富的库而受到欢迎。在Web开发领域,Python常用于后端...
6. 安装与配置:在Apache服务器上安装mod_fcgid,通常需要编译源码或通过包管理器安装预编译的二进制文件,然后在Apache配置文件中添加相应的配置指令,启用mod_fcgid并设置相关参数。 7. 性能优化:通过调整mod_...
`mod_aspdotnet-2.2.0.2006-setup-r2.msi`安装文件则意味着它可以让你的Apache服务器支持ASP.NET应用程序。ASP.NET是Microsoft开发的一种服务器端编程框架,用于构建动态Web应用。结合Apache2.2,这使得非Windows...
mod_perl与Perl一样强大,只是更快一些。 二、PHP入门 PHP站点的在线教程已经很棒了。在那里还有一些其他教程的链接。而本文的该部分将让你对PHP熟悉一点。我不可能做到没有任何遗漏,我的目的只在于能让你迅速...
- FastCGI和mod_proxy_fcgi可以将动态请求转发给FastCGI进程,提高性能。 12. **GZIP压缩**: - mod_deflate用于对HTTP响应内容进行GZIP压缩,减少网络传输量。 13. **防盗链设置**: - 通过`Referrer`检查限制...
<IfModule mod_proxy_fcgi.c> ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/var/www/html/$1 </IfModule> ``` **FastCGI进程管理器** FastCGI进程管理器负责创建、管理和终止FastCGI进程。PHP的php-fpm...
Apache 2.2支持多进程(MPM,Multi-Processing Modules)模型,如Prefork和Worker,以适应不同的服务器负载情况。`MaxKeepAliveRequests`和`KeepAliveTimeout`等设置可以优化连接处理和资源利用。 八、代理与缓存 ...
为了提升服务器性能,Apache 2.2提供了一些配置选项,如多进程(MPM)模型的选择,如Prefork、Worker和Event,每种模型有不同的性能特性。此外,调整`KeepAlive`、`MaxKeepAliveRequests`和`KeepAliveTimeout`等参数...
为了提高性能,Apache 2.2引入了多路复用(Multiplexing)模式,即“worker”MPM(多处理模块),允许一个父进程管理多个子进程,每个子进程可以同时处理多个连接。这显著减少了服务器对资源的需求,尤其是在高并发...
1. **安装与配置**:Apache的安装过程因操作系统而异,但通常包括下载最新版本的源代码或预编译二进制包,然后通过命令行工具进行编译和安装。配置文件`httpd.conf`是Apache的核心,用于定义服务器的行为,如监听...
`mpm`(多进程模块)如`prefork`和`worker`决定了服务器如何处理并发请求。`KeepAlive`和`MaxKeepAliveRequests`等参数可以调整连接保持和资源管理。 ### 8. CGI与FastCGI `mod_cgi`模块支持执行CGI(Common ...
随着技术的发展,CGI的缺点逐渐暴露,现在有更多高效且安全的解决方案,如FastCGI、mod_perl、PHP-FPM等,它们提高了性能并降低了安全风险。 总之,“CGI全面接触”资料会引导你全面了解CGI技术,学习如何使用Perl...