ubuntu10.04配置 nginx+php(2)


fastcgi_param   SCRIPT_NAME             $document_root$fastcgi_script_name;


因为脚本的名称不加上$document_root,php5-fpm是无法找到需要执行的php脚本的绝对路径的
重启nginx

复制代码 代码如下:


sudo  /etc/init.d/nginx  restart


测试fastcgi_finish_request()函数

复制代码 代码如下:


<?php
echo "OK";
fastcgi_finish_request(); /* 响应完成, 关闭连接 */
sleep(5);
file_put_contents("/tmp/fastcgi.log", "hello",FILE_APPEND);
sleep(5);
file_put_contents("/tmp/fastcgi.log", "world",FILE_APPEND);
?>


说明:
用最大的白话说,fastcgi_finish_request()可以提前关闭和客户端的连接,把需要返回的数据返回给客户端,但是函数之后的分支业务逻辑还是继续在后台运行!
php5-fpm日志按天分割脚本

复制代码 代码如下:


#!/bin/bash -
#1.php5-fpm日志存放路径
php5_fpm_logs_path="/var/log/php5-fpm/"
category_array=("access" "error")
#2.php5-fpm日志名后缀
postfix=`date -d '-1 days' +%Y%m%d`".log"
#3.php5-fpm日志切割
for category in ${category_array[*]}
do
 if [ -e $php5_fpm_logs_path/php5-fpm.$category.log ]
 then
  mv $php5_fpm_logs_path/php5-fpm.$category.log \
   $php5_fpm_logs_path/php5-fpm.$category.$postfix
 fi
done
#4.查找php5-fpm进程号,让其产生新的日志文件
php5fpm_pid=`ps -aux |grep -E 'php-fpm: master process'|grep -v 'grep'|awk '{print $2}'`
#USR1:Reopen log files,刷新nginx日志文件
kill -USR1 $php5fpm_pid

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wywwyg.html