APC3.1.9自动安装脚本For DirectAdmin with PHP-CLI

前面发过一个APC Shell Script For PHP-CGI,经过Zeraba的指导,使用apc.php看了下APC的命中率,发现无论怎样,命中数只有“1”,明显APC并没有发挥它应有的用途。同时也发现,不管是什么opcode的PHP组件,都是只能在探针那看个版本……

既然PHP-CGI有问题,那就换PHP-CLI,但是DirectAdmin的PHP-CLI模式也有问题,那就是无法以特定身份去创建执行PHP程序,这就使得用户的网站某些目录需要设置rwxrwxrwx,非常麻烦,而且也不安全。

要解决DirectAdmin的PHP-CLI的问题,大家可以参考:实现DirectAdmin使用PHP-CLI模式的站点独立用户与查看各用户资源占用情况

要给PHP-CLI添加APC,其实和前面CGI的那个方法差不多,只是一些二进制文件的目录有所改变。

这里是使用添加APC的Shell Script的方法:

 注意:

如果你添加APC后无法访问PHP文件,并且在Apache的错误日志(/var/log/httpd/error_log)里面找到如下错误信息:

错误信息

 

这很明显你在使用PHP5.2.17,因为PHP5.2,Zend Optimizer与APC不能共存。因此需要你手动修改php.ini,把加载Zend Optimizer的那行注释掉:

php.ini

如图,在zend_extension=/usr/local/lib/ZendOptimizer_5.2.so这行前面加个英文的”;”,然后重启apache就行了。

如果顺利完成上面几个步骤,访问几个PHP文件,再使用apc.php看看命中率,如果Hits数目那有变化,那证明APC正常了:

APC.PHP

实现DirectAdmin使用PHP-CLI模式的站点独立用户与查看各用户资源占用情况

用过DirectAdmin的都知道,CLI是个坑爹货:网站目录非rwxrwxrwx(777)权限无法写入,无法查看是哪个用户占用较多的资源,甚至无法正常使用opcode cache的PHP组件。

Wordpress

我们来研究下DirectAdmin的站点的配置文件:

关键,就在SuexecUserGroup这里,这里定义了站点的执行PHP脚本时所使用的用户身份,这样可以给不同网站的目录不同的所有者,且无需再特意给某些文件设置rwxrwxrwx(777)权限。

然而,这个东西在CGI模式下工作正常,而CLI却不正常。貌似mod_ruid2.c是SuPHP才有的吧?无mod_ruid2.c。Apache自然就忽略掉SuexecUserGroup的内容。

找到问题所在,要解决,就简单得多了。找个CLI上能实现类似功能的模块给Apache加上去就行。

看过我的LVAMP的介绍的,都知道,能实现站点独立用户,而且是CLI模式下实现的。其实真相只有一个——mpm-itk。

由于mpm-itk模块没提供2.2下能使用apxs编译的文件,因此添加有点麻烦。我这里写了一个Shell Script:

先下载:

然后运行:

执行完后,你会看到如下信息:

md5

那个是集成了mpm-itk源码的apache的源码的TGZ的MD5值。因为DirectAdmin的进行编译的Shell Script会自动验证所有源码包的MD5值,不一样就会帮你重新下载,所以就要修改一下DirectAdmin所记录的Apache的MD5值。

修改/usr/local/directadmin/custombuild/versions.txt:

在第六行(一般都是第六行),也就是apache2.2:2.2.24(一般都是2.2.24吧)的那一行,把冒号后面的MD5改成执行mpm-itk.sh后所显示的MD5值:

Versions

 

确认无误后,保存(用vim的话:wq)。

开始编译吧:

这个看你服务器配置了,一般十分钟左右吧……

顺利完成后,还有Apache的站点配置文件的模板要修改,不过文件有点多,直接执行这个Shell Script就好了:

最后在“服务监控”那,重启Apache(也就是httpd)。

再次测试安装Wordpress,已经可以成功写入文件了:

写入成功

 

在top那,httpd进程的执行身份不再是清一色的apache了:

TOP