寻觅生命中的那一片浅草......

每月存档 九月, 2009

Nginx下perl(fastcgi)配置

wget http://www.cpan.org/modules/by-module/FCGI/FCGI-0.67.tar.gz
tar xzf FCGI-0.67.tar.gz
cd FCGI-0.67
perl Makefile.PL
make
make install

wget http://www.cpan.org/modules/by-module/FCGI/FCGI-ProcManager-0.18.tar.gz
tar zxf FCGI-ProcManager-0.18.tar.gz
cd FCGI-ProcManager-0.18
perl Makefile.PL
make && make install

配置Perl的FastCGI脚本(从网上找到的,未找到原始出处):
#vi /etc/init.d/perl-fast

****************************************

#!/usr/bin/perl -w

use FCGI;

use Socket;

use FCGI::ProcManager;

sub shutdown { FCGI::CloseSocket($socket); exit; }

sub restart { FCGI::CloseSocket($socket); &main; }

use sigtrap ‘handler’, \&shutdown, ‘normal-signals’;

use sigtrap ‘handler’, \&restart, ‘HUP’;

require ‘syscall.ph’;

use POSIX qw(setsid);

#export FCGI_SOCKET_PATH=”/tmp/perl-fastcgi.sock”

#export FCGI_NPROCESSES=4

#&daemonize; we don’t daemonize when running under runsv

#this keeps the program alive or something after exec’ing perl scripts

END() { }

BEGIN() { }

{

no warnings;

*CORE::GLOBAL::exit = sub { die “fakeexit\nrc=” . shift() . “\n”; };

};

eval q{exit};

if ($@) {

exit unless $@ =~ /^fakeexit/;

}

&main;

sub daemonize() {

chdir ‘/’ or die “Can’t chdir to /: $!”;

defined( my $pid = fork ) or die “Can’t fork: $!”;

exit if $pid;

setsid() or die “Can’t start a new session: $!”;

umask 0;

}

sub main {

#…. IP sockets

#$socket = FCGI::OpenSocket( “127.0.0.1:8999”, 10 );

#…. UNIX sockets

#$socket = FCGI::OpenSocket( “/temp/perl-fastcgi.sock”, 10 );

#foreach $item (keys %ENV) { delete $ENV{$item}; }

#..fastcgi……..

my $n_processes = $ENV{FCGI_NPROCESSES} || 4;

$proc_manager = FCGI::ProcManager->new( {n_processes => $n_processes} );

#..unix socket

$socket = FCGI::OpenSocket( “$ENV{FCGI_SOCKET_PATH}”, 10 );

#..Socket..

chmod 0777, $ENV{FCGI_SOCKET_PATH};

; #use UNIX sockets – user running this script must have w access to the ‘nginx’ folder!!

$request =

FCGI::Request( \*STDIN, \*STDOUT, \*STDERR, \%req_params, $socket,

&FCGI::FAIL_ACCEPT_ON_INTR );

$proc_manager->pm_manage();

if ($request) { request_loop() }

FCGI::CloseSocket($socket);

}

sub request_loop {

while ( $request->Accept() >= 0 ) {

$proc_manager->pm_pre_dispatch();

#processing any STDIN input from WebServer (for CGI-POST actions)

$stdin_passthrough = ”;

{ no warnings; $req_len = 0 + $req_params{‘CONTENT_LENGTH’}; };

if ( ( $req_params{‘REQUEST_METHOD’} eq ‘POST’ ) && ( $req_len != 0 ) )

{

my $bytes_read = 0;

while ( $bytes_read < $req_len ) {

my $data = ”;

my $bytes = read( STDIN, $data, ( $req_len – $bytes_read ) );

last if ( $bytes == 0 || !defined($bytes) );

$stdin_passthrough .= $data;

$bytes_read += $bytes;

}

}

#running the cgi app

if (

( -x $req_params{SCRIPT_FILENAME} ) && #can I execute this?

( -s $req_params{SCRIPT_FILENAME} ) && #Is this file empty?

( -r $req_params{SCRIPT_FILENAME} ) #can I read this file?

)

{

pipe( CHILD_RD, PARENT_WR );

pipe( PARENT_ERR, CHILD_ERR );

my $pid = open( CHILD_O, “-|” );

unless ( defined($pid) ) {

print(“Content-type: text/plain\r\n\r\n”);

print

“Error: CGI app returned no output – Executing $req_params{SCRIPT_FILENAME} failed !\n”;

next;

}

$oldfh = select(PARENT_ERR);

$| = 1;

select(CHILD_O);

$| = 1;

select($oldfh);

if ( $pid > 0 ) {

close(CHILD_RD);

close(CHILD_ERR);

print PARENT_WR $stdin_passthrough;

close(PARENT_WR);

$rin = $rout = $ein = $eout = ”;

vec( $rin, fileno(CHILD_O), 1 ) = 1;

vec( $rin, fileno(PARENT_ERR), 1 ) = 1;

$ein = $rin;

$nfound = 0;

while ( $nfound =

select( $rout = $rin, undef, $ein = $eout, 10 ) )

{

die “$!” unless $nfound != -1;

$r1 = vec( $rout, fileno(PARENT_ERR), 1 ) == 1;

$r2 = vec( $rout, fileno(CHILD_O), 1 ) == 1;

$e1 = vec( $eout, fileno(PARENT_ERR), 1 ) == 1;

$e2 = vec( $eout, fileno(CHILD_O), 1 ) == 1;

if ($r1) {

while ( $bytes = read( PARENT_ERR, $errbytes, 4096 ) ) {

print STDERR $errbytes;

}

if ($!) {

$err = $!;

die $!;

vec( $rin, fileno(PARENT_ERR), 1 ) = 0

unless ( $err == EINTR or $err == EAGAIN );

}

}

if ($r2) {

while ( $bytes = read( CHILD_O, $s, 4096 ) ) {

print $s;

}

if ( !defined($bytes) ) {

$err = $!;

die $!;

vec( $rin, fileno(CHILD_O), 1 ) = 0

unless ( $err == EINTR or $err == EAGAIN );

}

}

last if ( $e1 || $e2 );

}

close CHILD_RD;

close PARENT_ERR;

waitpid( $pid, 0 );

} else {

foreach $key ( keys %req_params ) {

$ENV{$key} = $req_params{$key};

}

# cd to the script’s local directory

if ( $req_params{SCRIPT_FILENAME} =~ /^(.*)\/[^\/]+$/ ) {

chdir $1;

}

close(PARENT_WR);

#close(PARENT_ERR);

close(STDIN);

close(STDERR);

#fcntl(CHILD_RD, F_DUPFD, 0);

syscall( &SYS_dup2, fileno(CHILD_RD), 0 );

syscall( &SYS_dup2, fileno(CHILD_ERR), 2 );

#open(STDIN, “<&CHILD_RD”);

exec( $req_params{SCRIPT_FILENAME} );

die(“exec failed”);

}

} else {

print(“Content-type: text/plain\r\n\r\n”);

print

“Error: No such CGI app – $req_params{SCRIPT_FILENAME} may not exist or is not executable by this process.\n”;

}

}

}

****************************************************************************

#chmod +x  /etc/init.d/perl-fast

#vi /etc/profile

添加以下内容

export FCGI_SOCKET_PATH=”/tmp/perl-fastcgi.sock”

export FCGI_NPROCESSES=4

#source /etc/profile

#/etc/init.d/perl-fast&

为Nginx添加FastCGI的Perl支持
server {

listen       80;

server_name  mail.test5.com;

charset gb2312;

access_log  logs/access.log  main;

location / {

root   /share/htdocs;

index  index.php index.html;

}

location ~* .*\.pl$ {

root  /share/htdocs;

include perl.conf;

}

}

#vi perl.conf

————————————————————–

fastcgi_pass  unix:/tmp/perl-fastcgi.sock;

fastcgi_index openwebmail.pl;

fastcgi_param SCRIPT_FILENAME  $document_root$fastcgi_script_name;

fastcgi_param QUERY_STRING     $query_string;

fastcgi_param REQUEST_METHOD   $request_method;

fastcgi_param CONTENT_TYPE     $content_type;

fastcgi_param CONTENT_LENGTH   $content_length;

fastcgi_param GATEWAY_INTERFACE  CGI/1.1;

fastcgi_param SERVER_SOFTWARE    nginx;

fastcgi_param SCRIPT_NAME        $fastcgi_script_name;

fastcgi_param REQUEST_URI        $request_uri;

fastcgi_param DOCUMENT_URI       $document_uri;

fastcgi_param DOCUMENT_ROOT      $document_root;

fastcgi_param SERVER_PROTOCOL    $server_protocol;

fastcgi_param REMOTE_ADDR        $remote_addr;

fastcgi_param REMOTE_PORT        $remote_port;

fastcgi_param SERVER_ADDR        $server_addr;

fastcgi_param SERVER_PORT        $server_port;

fastcgi_param SERVER_NAME        $server_name;

fastcgi_read_timeout 60;

——————————————————————–
重启nginx

#Kill -HUP `cat /var/run/nginx.pid`

参考:http://blog.chinaunix.net/u/14353/showart_1668580.html

shell删除文本中每行特定字符串到行尾

文本文件tmp.txt中含有一下内容
cd $AICBS22/vgroup/busivpmn/server/atmi/;gmake -f Makefile.test clean;gmake -f Makefile.test
cd $AICBS22/vgroup/busivpmn/server/atmi/test/source/;gmake -f Makefile clean;gmake -f Makefile
cd $AICBS22/vgroup/busivpmn/server/mgr/;gmake -f Makefile clean;gmake -f Makefile
cd $AICBS22/vgroup/busivpmn/server/mgr/;gmake -f Makefile.mml clean;gmake -f Makefile.mml
cd $AICBS22/vgroup/busivpmn/server/mgr/;gmake -f Makefile.res clean;gmake -f Makefile.res
cd $AICBS22/vgroup/busivpmn/server/pmgr/;gmake -f Makefile clean;gmake -f Makefile
cd $AICBS22/vgroup/busivpmn/server/pmgr/;gmake -f Makefile.intf clean;gmake -f Makefile.intf
cd $AICBS22/vgroup/busivpmn/server/releaseVpmnPhone/;gmake -f Makefile clean;gmake -f Makefile
cd $AICBS22/vgroup/busivpmn/server/svr/;gmake -f Makefile clean;gmake -f Makefile
cd $AICBS22/vgroup/busivpmn/server/svr/;gmake -f Makefile.svr1 clean;gmake -f Makefile.svr1
cd $AICBS22/vgroup/busivpmn/server/syncvnextprod/;gmake -f Makefile clean;gmake -f Makefile
cd $AICBS22/vgroup/busivpmn/server/vpmnAsyncNextProd/;gmake -f Makefile clean;gmake -f Makefile
请各位老大看看这么写个shell。可以将每行中字符串clean后面的内容都去掉。
最后结果变为
cd $AICBS22/vgroup/busivpmn/server/atmi/;gmake -f Makefile.test clean
。。。
省略
。。。
cd $AICBS22/vgroup/busivpmn/server/vpmnAsyncNextProd/;gmake -f Makefile clean

解决
1、
grep -o ‘.*clean’ tmp.txt
2、
sed ‘s/\(.*clean\).*/\1/’ urfile

3、
awk -F ‘clean’ ‘{print $1″”FS}’ urfile

来自:http://blog.chinaunix.net/u2/72759/showart_1915246.html

SecureCRT无法使用SecureFX

Cannot connect to session “server.domain” due to configuration problem.

resolve:Open SecureCRT,Options–Session Options–Connection–Protocol–File Transfer, Choose file transer protocol
click ok
Now, you can use SecureFX!

转:我还能爱你吗?

每一个人都有自己的情感,曾经认为可以依附的东西,在需要的时候看起来竟然是如此无助,一度的改观之后,想想,也不过是如此罢了,曾经执着的坚持换来今天忽如其来一闪而过的念头:难道执着也是一种错?人的潜意识会令人感到害怕,尽管自己如何坚强的否认,变了就是变了~没办法回到从前也许是某些人心里永远的痛,但是事实就是事实,永远改变不了的事实,想想,给自己时间无论多久,会有明白的那一天…没理由的还是想一个人,能说得上是一种很熟悉的想念,那种想念的心情已经很久很久,像是心里已经尘埃落定,几年的思念,现在想想真的好累啊..但是那是种很平静的快乐,自己本来就不是个拿得起放得下的人,所以她,就这样住进我的心里,只想默默的喜欢,只想默默的想念,只想默默的在心里祈求她一定要过的很好,很幸福,纵使彼此都生活在不同世界里,纵使不知道她在忙什么.还是很喜欢,!!极力的控制的控制自己不去打听她的任何消息,但是朋友的突然提起,自己还是会忍不住的去问一句:她过的还好吗?喜欢着,关心着,而且还爱着,那种心情不知道还有谁真正能懂,几年的时间说长不长,说短不短,但足以改变一个人,就好像这次我的出现,对她对我,无疑都是一种沉默的伤害,当我知道我们之间的疏远,就开始已经疏离得让我好想流泪,所以就开始隐藏好所有我们的关系,隐藏好所有的悲伤不想让自己的感觉发觉,可是这真的做得到吗?做得到我就能不那么悲伤吗?很难过,很难过,原来真正难过的是怕自己真的不能再为她的事担心难过了,原来自己真正难过的,是忘了要难过些什么.听见了你的名字自己还有那种心跳的感觉,但是经过那么多少年了,伤痕应该让她看不见啊,这样子所有的寂寞的尊严才有可能回到我的身边,有时候以为我能微笑的去面对她所改变的一切一切,告诉自己能改变也是件好事,可是为什么我就觉得很伤心呢,有时心酸到呼吸都能自己听见,有时眼泪流得只有眼泪知道自己痛些什么?开始告诉自己:人难免常常会把回忆跟现实混在一起敷衍,听见她有她的所爱了,我也提醒自己应该学着自己去改变…不要将回忆,因为人真的会累.承受不了的就该学着去丢弃.逃避了那么久的现实,该面对的还是现实,心酸的背后只能坚持的依靠着自己,一次又一次的等待,一次又一次的失落,一次又一次期望,换来了一次又一次的失望,那种感觉,我不知道自己还能承受多久..开始学会忘记,刚开始学会慢慢放弃,我会的,我知道爱情是应该不要去计较付出与收获,但是我真的好累,我不知道怎样才可以令你多爱我一点,你对我好我是知道的,我不知道应该要怎么做啊,除了逃避,我想不出其他的办法…女人跟男人处理感情方面总会有些不同,如果可以选择的话,没有人想在苦恋的边缘拖拖拉拉,几年的感情,难道我最终要以一颗坚强的心去放弃呢段爱情亲情!

WordPress更新失败及解决方案

打开 wordpress\wp-admin\includes\file.php

找到 $response = wp_remote_get($url, array(‘timeout’ => 30)); 这一行,在function download_url( $url )这个函数中,如果使用的是 WordPress 2.7的话,那么在第444行。

将此行修改为: $response = wp_remote_get($url, array(‘timeout’ => 120));

将超时时间修改为2分钟,再次更新插件,哈哈,终于成功了!

转载自:http://blog.zxlm.cn/show-12568-1.html

2009年九月
« 8月   10月 »
 123456
78910111213
14151617181920
21222324252627
282930