在写完《php-memcached扩展升级小记》这篇文章后,总觉得思考的还不够深入,所以又仔细学习了下,从而对PHP有了进一步的理解。
《php-memcached扩展升级小记》描述了 PECL 和 apt-get 安装 php-memcached 扩展(其他的php扩展类似)的方法,这两种都属于比较傻瓜式的方法,隐藏了很多细节,一般情况下,不管采用源代码编译还是包安装方式(比如apt-get)安装 PHP 后,都面临一个问题,如果需要安装一个php扩展,需要重新编译吗?
如果你采用源代码方式编译 PHP,那么可以通过 phpize 来编译安装扩展,无需重新编译 PHP ;而如果 PHP 采用包安装方式,那么扩展安装也非常方便,但内部好像并没有采用了phpize来进行编译(后面会提到)。
现在重点来了,重点讲解 phpize 相关内容,它是一种安装php扩展的工具,如果想安装一个php扩展,但 PECL 没有支持该扩展;或者该扩展版本比较高,apt-get包安装不支持该版本,那么只能通过 phpize 安装了。
如何描述 phpize 呢?可以参考:
phpize is a shell script to prepare PHP extension for compiling.
接下去我在ECS(Ubuntu)上讲解如何使用 phpize,演示的例子还是php-memcached扩展的安装,使用的 PHP 版本是php 7.1,通过 apt-get 安装。
看过《php-memcached扩展升级小记》这篇文章的同学都知道,在 ECS 上我已经使用apt安装了php-memcached扩展,首先先卸载它,然后手动使用phpize重新编译安装。
卸载命令如下:
$ apt-get purge php-memcached
注意该命令并不会卸载php-memcached扩展的依赖包libmemcached,如果你也想卸载,可以执行下列命令:
# 寻找依赖
$ apt-cache depends php-memcached
# 可以看出libmemcached最主要提供了一个.so文件
$ dpkg -L libmemcached11
$ apt-get purge libmemcached11
接下去寻找php-memcached扩展的源代码,脑洞一下,如果你想安装一个其他的php扩展,也可以去特定的仓库寻找,php-memcached的包可以在 https://github.com/php-memcached-dev 找到。
执行下列命令:
$ git clone https://github.com/php-memcached-dev/php-memcached memcached
$ cd memcached/
$ phpize
在我的ECS上运行上列命令,显示 phpize 不存在,这也说明我使用apt-get安装php的时候,并没有提供phpize,那么如何安装 phpize 呢?
其实它由php7.1-dev包(php7.2,则是php7.2-dev,以此类推)提供,执行下列命令:
$ apt-get install php7.1-dev
php7.1-dev这个包定义如下:
This package provides the files from the PHP7.1 source needed for compiling
additional modules.
直白的说,提供了一些编译环境,主要包含的两个工具是php-config7.1和phpize7.1。
php-config7.1显示apt-get安装php7.1采用的编译参数,可以执行下看看输出。phpize则是本文讲解的重点,有了phpize执行环境后,接着运行:
$ /usr/bin/phpize7.1
# 配置参数,需要链接libmemcached
$ ./configure --with-libmemcached-dir=/usr/lib/x86_64-linux-gnu
还是会提示错误,手动查看/usr/lib/x86_64-linux-gnu/libmemcached.so.11 文件也存在啊,这个so是由apt-get install libmemcached11
提供的。
采用phpize编译,必须连接.h头文件,为了提供libmemcahced对应的头文件,可以执行下列命令安装:
$ apt-get install libmemcached-dev
# 可以看到 /usr/include/libmemcached/memcached.h 头文件
$ dpkg -L libmemcached-dev
现在妥妥的再一次执行:
$ ./configure --with-libmemcached-dir=/usr/lib/x86_64-linux-gnu
可还是报错…,原因在于phpize要去php-memcached源代码目录寻找libmemcached的.h头文件,执行下令命令就能解决:
$ mkdir -p /usr/lib/x86_64-linux-gnu/include/libmemcached/
$ ln -s /usr/include/libmemcached/memcached.h /usr/lib/x86_64-linux-gnu/include/libmemcached/memcached.h
$ ./configure --with-libmemcached-dir=/usr/lib/x86_64-linux-gnu
$ make
$ make install
成功编译后,安装的php-memcached扩展存储在 /etc/php/7.1/mods-available 目录下,那么如何启用php-memcached呢?不用手动配置,一个命令就能够解决:
# 可以对php所有的sapi(cli、php-fpm等等)启用该模块
$ phpenmod php-memcached
phpenmod 来源于哪儿呢?php7.1-common 包提供了很多有用的命令,比如:
$ phpdismod php-memcached
$ phpquery -v 7.1 -s cli -M
基本上讲完了,学到哪儿就说到哪儿,进一步理解了phpize,当然还有很多知识待学习,比如php编译到底发生了什么?phpize内部到底怎么运作的,有机会我还会持续分享的。
【这篇文章于2018-10-17号发表于公众号,地址https://mp.weixin.qq.com/s/v2FvcJd_SDob19ToXxLWIA,也可以关注我的公众号(ID:yudadanwx,虞大胆的叽叽喳喳)】