PHP安装
--prefix=/usr/local/php
指定 php 安装目录
--with-apxs2=/usr/local/apache/bin/apxs
整合 apache,apxs功能是使用mod_so中的LoadModule指令,加载指定模块到 apache,要求 apache 要打开SO模块
--with-config-file-path=/usr/local/php/etc
指定php.ini位置
--with-MySQL=/usr/local/mysql
mysql安装目录,对mysql的支持
--with-mysqli=/usr/local/mysql/bin/mysql_config
mysqli扩展技术不仅可以调用MySQL的存储过程、处理MySQL事务,而且还可以使访问数据库工作变得更加稳定。
--enable-safe-mode 打开安全模式
--enable-ftp 打开ftp的支持
--enable-zip 打开对zip的支持
--with-bz2 打开对bz2文件的支持
--with-jpeg-dir 打开对jpeg图片的支持
--with-png-dir 打开对png图片的支持
--with-freetype-dir 打开对freetype字体库的支持
--without-iconv 关闭iconv函数,种字符集间的转换
--with-libXML-dir 打开libxml2库的支持
--with-XMLrpc 打开xml-rpc的c语言
--with-zlib-dir 打开zlib库的支持
--with-gd 打开gd库的支持
--enable-gd-native-ttf 支持TrueType字符串函数库
--with-curl 打开curl浏览工具的支持
--with-curlwrappers 运用curl工具打开url流
--with-ttf 打开freetype1.*的支持,可以不加了
--with-xsl 打开XSLT 文件支持,扩展了libXML2库 ,需要libxslt软件
--with-gettext 打开gnu 的gettext 支持,编码库用到
--with-pear 打开pear命令的支持,PHP扩展用的
--enable-calendar 打开日历扩展功能
--enable-mbstring 多字节,字符串的支持
--enable-bcmath 打开图片大小调整,用到zabbix监控的时候用到了这个模块
--enable-sockets 打开 sockets 支持
--enable-exif 图片的元数据支持
--enable-magic-quotes 魔术引用的支持
--disable-rpath 关闭额外的运行库文件
--disable-debug 关闭调试模式
--with-mime-magic=/usr/share/file/magic.mime 魔术头文件位置
CGI方式安装才用的参数
--enable-fpm
打上PHP-fpm 补丁后才有这个参数,CGI方式安装的启动程序
--enable-fastCGI
支持fastcgi方式启动PHP
--enable-force-CGI-redirect
重定向方式启动PHP
--with-ncurses
支持ncurses 屏幕绘制以及基于文本终端的图形互动功能的动态库
--enable-pcntl freeTDS需要用到的,可能是链接mssql 才用到
mhash和mcrypt算法的扩展
--with-mcrypt 算法
--with-mhash 算法
以上函数库需要安装
--with-gmp 应该是支持一种规范
--enable-inline-optimization 优化线程
--with-openssl openssl的支持,加密传输时用到的
--enable-dbase 建立DBA 作为共享模块
--with-pcre-dir=/usr/local/bin/pcre-config perl的正则库案安装位置
--disable-dmalloc
--with-gdbm dba的gdbm支持
--enable-sigchild
--enable-sysvsem
--enable-sysvshm
--enable-zend-multibyte 支持zend的多字节
--enable-mbregex
--enable-wddx
--enable-shmop
--enable-soap
关于 mysqlnd :
问:Mysqlnd是什么?
答:Mysqlnd,全称是 MySQL Native Driver,MySQL原生驱动,简单说它是一个PHP官方的MySQL数据库驱动。
问:搞这个库干什么?
答:我估计最重要的是版权问题,这个库是自己人码代码的,用的PHP License,所以不会用到原来的libmysql之类的,避免版权纠纷。大家都知道,PHP4中MySQL函数是作为默认支持的,最明显的在Windows下安装,是不需要有个libmysql.dll,后来PHP5就一直要这个dll,这个dll应该是MySQL官方提供的。PHP不爽,自己写个算了,嗯。因此有了Mysqlnd。
问:它和mysql、mysqli有啥区别?
答:这个问题问得好,我一开始就是搞不明白,原来呢,这两个函数库默认调用的是MySQL客户端库(By default the MySQL database extensions are configured to use MySQL Client Library直译)的,这个时候Linux上是需要安装MySQL客户端(当然我不知道MySQL客户端和MySQL客户端库有啥区别,暂时不管),但是用Mysqlnd好像不用了,只需要直接with绑定一下mysqlnd即可:
--with-mysql=mysqlnd \
--with-mysqli=mysqlnd \
--with-pdo-mysql=mysqlnd \
问:我还能不能使用mysql_*、mysqli_*函数?
答:看到以上编译PHP的选项,就知道mysqlnd和mysql、mysqli函数库的关系了。Mysqlnd是更底层的驱动支持。设置了使用Mysqlnd后,这些函数库就会使用Mysqlnd来调用MySQL的API了。简单说,mysql_*、mysqli_*照用不误啦,和这两组函数库没啥太大影响。只不过是底层的调用被换掉而已。虚惊一场!
问:我没看出有啥好处?
答:好处就是自己写的代码,爽,独占!另外就是不需要用MySQL官方提供的Client Library了,原生支持嘛,安装PHP的时候不需要再折腾MySQL了(否则configure的时候是要指定MySQL Client Library的path的。--with-mysql[=DIR])。另外估计就是底层的,性能上的改善什么的,可以忽略了(这么说会被扁!)。
问:我也没看出什么坏处?
答:估计不太稳定,看了下5.3.6里的Mysqlnd是dev版(mysqlnd 5.0.8-dev - 20102224 - $Revision: 308673 $)。
转存base64编码图片等数据如果需要用到正则会开销很大 =。= 需要做如下修改 原来貌似是10000 要加多几个0 =。=
[Pcre]
pcre.recursion_limit=10000000
pcre.backtrack_limit=10000000
开启gzip压缩
; http://php.net/zlib.output-compression
zlib.output_compression = on
; http://php.net/zlib.output-compression-level
zlib.output_compression_level = 9
成功后可以看到Content-Encoding gzip了