一、perl + mod_perl
安装mod_perl使perl脚本速度快
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
[1] 安装mod_perl # 从epel安装 [root@linuxprobe ~] # yum --enablerepo=epel -y install mod_perl [2] 配置perlrun模式,总是将perl解释器放在 ram 上。 [root@linuxprobe ~] # vi /etc/httpd/conf.d/perl.conf # line 15: 取消注释 ( check codes and output warnings to logs ) perlswitches -w # line 24: 取消注释 perlswitches -t # line 30-36: 取消注释像下面一样 alias /perl /var/www/perl <directory /var/www/perl > # the directory for mod_perl environment sethandler perl-script # processes files as perl-scripts under this directory # addhandler perl-script .cgi # set specific extension if do do not want to processes all files as cgi # perlresponsehandler modperl::registry perlresponsehandler modperl::perlrun # specify perlrun mode perloptions +parseheaders options +execcgi < /directory > # line 43-49: 取消注释并添加如下信息 <location /perl-status > sethandler perl-script perlresponsehandler apache2::status require ip 127.0.0.1 10.1.1.1 /24 # add access permission # order deny,allow # deny from all # allow from .example.com < /location > [root@linuxprobe ~] # systemctl restart httpd [3] 创建测试脚本以确保设置不是ploblem。如果显示如下所示的结果,就可以。 [root@linuxprobe ~] # mkdir /var/www/perl [root@linuxprobe ~] # vi /var/www/perl/test-mod_perl.cgi #!/usr/bin/perl use strict; use warnings; print "content-type: text/html\n\n" ; print "<html>\n<body>\n" ; print "<div style=\"width:100%; font-size:40px; font-weight:bold; text-align:center;\">" ; my $a = 0; &number(); print "</div>\n</body>\n</html>" ; sub number { $a++; print "number \$a = $a" ; } [root@linuxprobe ~] # chmod 705 /var/www/perl/test-mod_perl.cgi #客户端浏览器访问:http://linuxprobe.org/perl/test-mod_perl.cgi |
[4] 配置在ram上具有代码缓存的注册表模式
1
2
3
4
5
6
7
8
9
10
11
12
13
|
[root@linuxprobe ~] # vi /etc/httpd/conf.d/perl.conf alias /perl /var/www/perl <directory /var/www/perl > sethandler perl-script perlresponsehandler modperl::registry # uncomment # perlresponsehandler modperl::perlrun # comment out perloptions +parseheaders options +execcgi < /directory > [root@linuxprobe ~] # systemctl restart httpd |
[5] 访问作为[4]节的示例的测试脚本,然后变量通过重新加载而增加,因为变量被高速缓存在ram上。所以有必要编辑注册表模式的代码,这里浏览器没刷新一次,$a值加一。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
[root@linuxprobe ~] # vi /var/www/perl/test-mod_perl.cgi #!/usr/bin/perl use strict; use warnings; print "content-type: text/html\n\n" ; print "<html>\n<body>\n" ; print "<div style=\"width:100%; font-size:40px; font-weight:bold; text-align:center;\">" ; my $a = 0; &number($a ); print "</div>\n</body>\n</html>" ; sub number { my($a) = @_; $a++; print "number \$a = $a" ; } |
[6]顺便说一下,可以看到mod_perl的状态来访问“http://(主机名或ip地址)/ perl-status”。
二、php + php-fpm
安装php-fpm使php脚本速度快
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
[1]安装php,请参考这里。 [2]安装php-fpm。 [root@linuxprobe ~] # yum -y install php-fpm [3] 配置apache httpd。 [root@linuxprobe ~] # vi /etc/httpd/conf.d/php.conf # line 5: change like follows <filesmatch \.php$> # sethandler application /x-httpd-php sethandler "proxy:fcgi://127.0.0.1:9000" < /filesmatch > [root@linuxprobe ~] # systemctl start php-fpm [root@linuxprobe ~] # systemctl enable php-fpm [root@linuxprobe ~] # systemctl restart httpd [4]创建phpinfo并访问它,然后如果“fpm / fastcgi”显示,它是确定。 [root@linuxprobe ~] # echo '<?php phpinfo(); ?>' > /var/www/html/info.php |
三、python + mod_wsgi
安装mod_wsgi(wsgi:web服务器网关接口),使python脚本更快
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
[1] 安装mod_wsgi . [root@linuxprobe ~] # yum -y install mod_wsgi [2] 例如,将mod_wsgi配置为可以访问/ test_wsgi,后端是 /var/www/html/test_wsgi .py. [root@linuxprobe ~] # vi /etc/httpd/conf.d/wsgi.conf # create new wsgiscriptalias /test_wsgi /var/www/html/test_wsgi .py [root@linuxprobe ~] # systemctl restart httpd [3] 创建您在上面设置的测试脚本. [root@linuxprobe ~] # vi /var/www/html/test_wsgi.py # create new def application(environ,start_response): status = '200 ok' html = '<html>\n' \ '<body>\n' \ '<div style="width: 100%; font-size: 40px; font-weight: bold; text-align: center;">\n' \ 'mod_wsgi test page\n' \ '</div>\n' \ '</body>\n' \ '</html>\n' response_header = [( 'content-type' , 'text/html' )] start_response(status,response_header) return [html] |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
[4]配置如果你使用django。 ([参考安装django](http: //blog .csdn.net /wh211212/article/details/52992413 ))例如,在“wang”下拥有的“ /home/wang/ venv /testproject ”下配置“testapp” [root@linuxprobe ~] # vi /etc/httpd/conf.d/django.conf # create new wsgidaemonprocess testapp python-path= /home/wang/venv/testproject : /home/wang/venv/lib/python2 .7 /site-packages wsgiprocessgroup testapp wsgiscriptalias /django /home/wang/venv/testproject/testproject/wsgi .py <directory /home/wang/venv/testproject > require all granted < /directory > [root@linuxprobe ~] # systemctl restart httpd |
四、访问日志分析器:awstats
安装awstats,它报告http日志以分析对http服务器的访问。
[1] 安装awstats。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
# install from epel [root@linuxprobe ~] # yum --enablerepo=epel -y install awstats # awstats.(hostname).conf是自动生成的 [root@linuxprobe ~] # vi /etc/awstats/awstats.linuxprobe.org.conf # line 122: change # if your config for log format in httpd.conf is 'combined' set here '1' # if log-config is 'common' set here '4', but in this case, some informations can't be get (browser info and so on) logformat=1 # line 153: specify your hostname sitedomain="linuxprobe.org # line 168: set ip address you'd like to exclude hostaliases="localhost 127.0.0.1 regex[server\.world$] regex[^10\.1\.1\.] " [root@linuxprobe ~] # vi /etc/httpd/conf.d/awstats.conf # line 30: ip address you permit to access require ip 10.1.1.0 /24 [root@linuxprobe ~] # systemctl restart httpd # generate reports ( reports are updated for hourly by cron ) [root@linuxprobe ~] # /usr/share/awstats/linuxproberoot/cgi-bin/awstats.pl -config=linuxprobe.org -update create /update database for config "/etc/awstats/awstats.linuxprobe.org.conf" by awstats version 7.4 (build 20150714) from data in log file "/var/log/httpd/access_log" ... phase 1 : first bypass old records, searching new record... searching new records from beginning of log file ... phase 2 : now process new records (flush history on disk after 20000 hosts)... jumped lines in file : 0 parsed lines in file : 165 found 0 dropped records, found 0 comments, found 0 blank records, found 0 corrupted records, found 0 old records, found 165 new qualified records. |
[2]访问“http://(您的服务器的名称或ip地址/)/awstats/awstats.pl”,然后显示以下屏幕,可以看到httpd日志报告。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/wh211212/article/details/52994505