分类目录归档:code

php-fpm 5.3.3 rpm package with root privileges for centos/redhat 6

出于安全的考虑从源里面安装的php-fpm是不允许以root权限运行的

ERROR: [pool www] please specify user and group other than root

但是有些时候确实需要root权限,可以使用我打的开放root版本

php-fpm-5.3.3-1.i_want_root.el6.i386.rpm
php-fpm-5.3.3-1.i_want_root.el6.x86_64.rpm

如果想打其他php版本的包,可以修改下面的脚本使用

#!/bin/sh
yum install rpm-build gcc make subversion wget
yum install bzip2-devel gmp-devel zlib-devel pcre-devel libxml2-devel openssl-devel
test ! -f ./autoconf-2.13-8.noarch.rpm && wget "http://rpm.bluehua.org/php-fpm/autoconf-2.13-8.noarch.rpm"
rpm -e autoconf
rpm -ivh ./autoconf-2.13-8.noarch.rpm
#修改源码版本
test ! -f ./php-5.3.3.tar.bz2 && wget "http://museum.php.net/php5/php-5.3.3.tar.bz2"
tar jxvf ./php-5.3.3.tar.bz2
cd php-5.3.3/
rm -rf ./sapi/fpm/
#选择适当的php-fpm版本
svn co http://svn.php.net/repository/php/php-src/branches/PHP_5_3_10/sapi/fpm/ ./sapi/fpm
./buildconf --force
test ! -f ./php-fpm-build-rpm.tar.gz && wget "http://rpm.bluehua.org/php-fpm/php-fpm-build-rpm.tar.gz"
tar zxvf ./php-fpm-build-rpm.tar.gz
#修改php-fpm.spec中的版本号
rpmbuild -bb ./php-fpm.spec

一个函数搞定PHP调试日志

对,你没有看错,不是syslog,也不是一坨class,一个函数搞定。。。
—————————-
今天有个搞C++同事问我PHP怎么打印日志,于是贴了他一个函数,绝对实用~
https://gist.github.com/emptyhua/5055043

function debug_log() {
    if (false) return; //开关
    static $fp = 0;
    if ($fp === 0) {
        $logname = 'myprojectname';//日志名称
        $fp = fopen('/tmp/' . $logname . '.debug.log', 'a');
    } 
    $traces = debug_backtrace();
    $trace = count($traces) > 1 ? $traces[1] : $traces[0];
    $log_msg = date('Y-m-d H:i:s') . ' FILE:' . basename($trace['file']) . ' FUNC:' . $trace['function'] . ' LINE:' . $trace['line'] . ' :' . "\n";
    foreach(func_get_args() as $arg) {
        if (is_string($arg)) {
            $log_msg .= $arg . ' ';
        } else {
            $log_msg .= var_export($arg, true) . ' ';
        }
    }
    fwrite($fp, $log_msg . "\n");
}
debug_log('队列ID:', $queue_id, '内容:', $task_infos);
2013-02-28 16:53:40 FILE:task.inc.php FUNC:_get_locate_task LINE:347
队列ID: locate337512971_taskqueue 内容: array (
)