最近在做php连接redis的实验,遇到一个问题语法是php代码直接使用php命令来测试是没有问题的。使用lnmp环境也是没有问题的,但是lamp就是不可以,最后查看http的日志终于找到问题所在了。
php测试代码如下:
http log:
[sun apr 24 23:06:47 2016] [notice] sighup received. attempting to restartphp warning: php startup: redis: unable to initialize module\nmodule compiled with module api=20121212\nphp compiled with module api=20100525\nthese options need to match\n in unknown on line 0[sun apr 24 23:06:47 2016] [notice] apache/2.2.29 (unix) php/5.4.45 configured -- resuming normal operations[sun apr 24 23:24:21 2016] [notice] sighup received. attempting to restartphp warning: php startup: redis: unable to initialize module\nmodule compiled with module api=20121212\nphp compiled with module api=20100525\nthese options need to match\n in unknown on line 0[sun apr 24 23:24:21 2016] [notice] apache/2.2.29 (unix) php/5.4.45 configured -- resuming normal operations
分析:
日志非常明显的说明当时编译php使用的api为“api=20100525”,而redis编译使用的api为“api=20121212”
ps:由于之前多次安装过不同版本的apache,所以我自己都不清楚当时编译php时使用的那个版本了(有点尴尬:()
解决方法如下:使用yum安装一个高版本的httpd,然后重新启动一个httpd服务就可以了(把配置文件和webroot更新一下)。
测试:
curl -x 127.1.1.1:80 www.cf.com/session.php 1461514249
1461514249
r05vrgop80r2f75t91ss1a2lv5
以上就介绍了php startup redis: unable to initialize module,包括了initialize,startup方面的内容,希望对php教程有兴趣的朋友有所帮助。
