再议php-memcached扩展的编译,进一步理解phpize

在写完《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,虞大胆的叽叽喳喳)】

    原文作者:虞大胆的叽叽喳喳
    原文地址: https://www.jianshu.com/p/567e98bdad14
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞