麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Perl > 正文

Perl使用nginx FastCGI環境做WEB開發實例

2020-10-31 15:16:37
字體:
來源:轉載
供稿:網友

Hello World

一個簡單的hello world例子:

復制代碼 代碼如下:

#!/usr/bin/env perl
use strict;
use warnings;
use CGI::Fast;
while(my $q = new CGI::Fast)
{
 print $q->header("text/plain");
 print "Hello World";
}

和CGI的區別僅在于多了一個循環來接受請求,CGI::Fast對象和CGI接口是一樣的,而且該腳本也可以當做CGI腳本使用。

搭建nginx + FastCGI 環境

Perl使用CGI::Fast包來提供FastCGI服務,該包提供兩種方式來啟動FastCGI進程,一個是直接使用該包提供的服務將當前進程變為FastCGI進程,另外一個是使用第三方工具spawn-fcgi來啟動。
nginx配置方式例子:

復制代碼 代碼如下:

        location / {
            fastcgi_pass   127.0.0.1:8184;
            fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
            include        fastcgi_params;
        }

配置好nginx后,使用spawn-fcgi來啟動前面的Hello World:
復制代碼 代碼如下:

$ spawn-fcgi -n -a 127.0.0.1 -p 8184 -f ./main.pl


調試支持

在前面的命令行里使用了參數-n,讓spawn-fcgi不要fork出多個進程,并阻塞,允許用戶Ctrl+C來關閉,產品服務器可以去掉這個參數來充分利用服務器的多核來提供更高的并發數。我之前寫了一個bash腳本,允許在文件改動的情況下重啟服務,方便調試perl程序,代碼如下:

復制代碼 代碼如下:

#!/bin/bash
#PID文件和需要啟動的腳本
PID_FILE=service.pid
MAIN=main.pl

#關閉之前啟動的進程
term() {
    test -e $PID_FILE || return
    pid=`cat $PID_FILE`
    kill -s -0 $pid  || return
    echo "Terminating $MAIN $pid"
    rm -f $PID_FILE
    kill $pid
    wait $pid
}
#當前腳本退出的時候也關閉啟動了的FastCGI進程
trap "term;exit" SIGINT SIGTERM
while true
do
#首次啟動或者文件改動后都需要關閉之前的進程
    term
#以no fork方式啟動腳本來調試,并將PID寫入到文件
    spawn-fcgi -n -a 127.0.0.1 -p 8184 -f ./$MAIN  &
    pid=$!
    echo $pid > $PID_FILE
    echo "My Perl service started, pid = $pid"
#監控文件變化
    files=`find . -name '*.pl' -o -name '*.pm' -o -name '*.html'`
    md5=`md5sum $files|md5sum`
#wait for file change
    while [[ `md5sum $files|md5sum` = "$md5" ]]
    do
        sleep 1
    done
    echo "File changes detected, restarting service"
done


該腳本已在Mac OSX和Linux下測試通過

路由系統

做Web開發離不開路由實現,來對不同請求來做出特定的響應。
路由請求依賴HTTP Method和URI兩部分,因此主要就是需要這兩者來做分派。
在CGI中可以通過環境變量REQUEST_METHOD和REQUEST_URI來獲取請求方法和URI。
因此一個簡單的路由系統實際上可以分解為一個二級的map,注冊路由實際上就是往這個map里放入規則對應的處理函數,而分派請求則是從這個map里根據規則獲取對應的處理函數,一個簡單的例子:

復制代碼 代碼如下:

my %routers = ();

sub not_found
{
    print "Status: 404/n";
    print "Content-Type: text/html/n/n";
    print<<EOF
<html>
<body>
<h1>404 Not found</h1>
Cannot find $ENV{REQUEST_PATH}.
</body>
</html>
EOF
}


sub add_rule
{
    my ($method, $path, $callback) = @_;
    my $handlers = $routers{$method};
    $handlers = $routers{$method} = {} if not $handlers;
    $handlers->{$path} = $callback;
}

sub dispatch
{
    my $q = shift;
    my $method = $ENV{REQUEST_METHOD};
    my $uri = $ENV{REQUEST_URI};
    $uri =~ s//?.*$//;
    my $handler = ($routers{$method} || {})->{$uri} || not_found;
    eval
    {
 &$handler($q);
    };
    print STDERR "Failed to handle $method $uri: $@/n" if $@;
}


使用這個路由系統的例子:
復制代碼 代碼如下:

sub index
{
    my ($q) = @_;
    print $q->header('text/plain');
    print "Hello World!";
}

router::add_rule('GET', '/', /&index);


模板系統

perl提供了大量的模板系統的實現,我個人最喜歡的是Template Toolkit,文檔也非常豐富,網站是 http://www.template-toolkit.org/ 。

將前面的index修改為使用模板的例子:

復制代碼 代碼如下:

use Template;

my $tt = new Template({INCLUDE_PATH => 'templates', INTERPOLATE => 1});

sub index
{
    my ($q) = @_;
    my $output = '';
    print $q->header('text/html');

    $tt->process('index.html', {world => 'World'}, $output) || die $tt->error();
    print $output;
}


其中templates/index.html文件內容如下:
復制代碼 代碼如下:

<html>
<head><title>Demo</title></head>
<body>
Hello ${world}
</body>
</html>

完!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 成人免费一区二区三区在线观看 | 国产亚洲激情 | 久久91精品 | 欧美一区二区片 | 久久久久久三区 | 欧美日韩激情 | 国产成人免费精品 | 在线日韩av电影 | 精品国产91一区二区三区 | 久久久久免费电影 | 一级毛片免费高清视频 | 韩国精品一区二区三区四区五区 | 免费看真人a一级毛片 | 久久久国产一级片 | 蜜桃欧美性大片免费视频 | 久久9久久 | 国产精品18久久久久久久 | 免费黄色大片在线观看 | 免费一级欧美 | 欧美性受xxx黑人xyx性爽 | 国产精品伦视频看免费三 | 日韩精品中文字幕一区二区三区 | 成人一级片毛片 | 精品中文字幕视频 | 精品国产乱码久久久久久丨区2区 | 欧美a∨一区二区三区久久黄 | 国产羞羞视频在线免费观看 | 黄色大片网 | 日本黄色免费片 | 欧美激情综合网 | 久久超 | 538任你躁在线精品视频网站 | h色视频在线观看 | 泰剧19禁啪啪无遮挡 | 久久精品亚洲一区 | 久久经典免费视频 | 1314成人网 | 无遮挡一级毛片视频 | 国产精品视频2021 | 日本一区二区在线看 | 日本不卡二区 |