Swoole 扩展是按照 PHP 标准扩展构建的。使用 phpize 来生成编译检测脚本,./configure 来做编译配置检测,make 进行编译,make install 进行安装。
如无特殊需求,请务必编译安装 Swoole 的最新 release 版本或 v4.4LTS
如果当前用户不是 root,可能没有 PHP 安装目录的写权限,安装时需要 sudo 或者 su
如果是在 git 分支上直接 git pull 更新代码,重新编译前务必要执行 make clean
仅支持 Linux(2.3.32 以上内核)、FreeBSD、MacOS 三种操作系统,低版本 Linux 系统(如 CentOS 6)可以使用 RedHat 提供的 devtools 编译,参考文档, 在 Windows 平台,可使用 CygWin 或 WSL(Windows Subsystem for Linux)
部分扩展与 Swoole 扩展不兼容,参考扩展冲突
安装前必须保证系统已经安装了下列软件
php-7.1 或更高版本
gcc-4.8 或更高版本
make
autoconf
1. 下载 swoole 源码
https://github.com/swoole/swoole-src/releases
http://pecl.php.net/package/swoole
http://git.oschina.net/swoole/swoole
2. 从源码编译安装
下载源代码包后,在终端进入源码目录,执行下面的命令进行编译和安装
ubuntu 没有安装 phpize 可执行命令:sudo apt-get install php-dev 来安装 phpize
cd swoole-src && \
phpize && \
./configure && \
make && sudo make installCopy to clipboardErrorCopied
3. 启用扩展
编译安装到系统成功后,需要在 php.ini 中加入一行 extension=swoole.so 来启用 Swoole 扩展
初次接触 Swoole 的开发者请先尝试上方的简单编译,如果有进一步的需要,可以根据具体的需求和版本,调整以下示例中的编译参数。编译参数参考
以下脚本会下载并编译 master 分支的源码,需保证你已安装所有依赖,否则会遇到各种依赖错误
mkdir -p ~/build && \
cd ~/build && \
rm -rf ./swoole-src && \
curl -o ./tmp/swoole.tar.gz https://github.com/swoole/swoole-src/archive/master.tar.gz -L && \
tar zxvf ./tmp/swoole.tar.gz && \
mv swoole-src* swoole-src && \
cd swoole-src && \
phpize && \
./configure \
--enable-openssl \
--enable-http2 && \
make && sudo make installCopy to clipboardErrorCopied
注意: PECL 发布时间晚于 Github 发布时间
Swoole 项目已收录到 PHP 官方扩展库,除了手工下载编译外,还可以通过 PHP 官方提供的 pecl 命令,一键下载安装
pecl install swooleCopy to clipboardErrorCopied
最后,编译安装成功后,修改 php.ini 加入
extension=swoole.soCopy to clipboardErrorCopied
通过 php -m 来查看是否成功加载了 swoole.so,如果没有可能是 php.ini 的路径不对。
可以使用 php --ini 来定位到 php.ini 的绝对路径,Loaded Configuration File 一项显示的是加载的 php.ini 文件,如果值为 none 证明根本没加载任何 php.ini 文件,需要自己创建。
对 PHP 版本支持和 PHP 官方维护版本保持一致,参考 PHP 版本支持时间表
ARM 平台(树莓派 Raspberry PI)
使用 GCC 交叉编译
在编译 Swoole 时,需要手工修改 Makefile 去掉 -O2 编译参数
MIPS 平台(OpenWrt 路由器)
使用 GCC 交叉编译
Windows WSL
Windows 10 系统增加了 Linux 子系统支持,BashOnWindows 环境下也可以使用 Swoole。安装命令
apt-get install php7.0 php7.0-curl php7.0-gd php7.0-gmp php7.0-json php7.0-mysql php7.0-opcache php7.0-readline php7.0-sqlite3 php7.0-tidy php7.0-xml php7.0-bcmath php7.0-bz2 php7.0-intl php7.0-mbstring php7.0-mcrypt php7.0-soap php7.0-xsl php7.0-zip
pecl install swoole
echo 'extension=swoole.so' >> /etc/php/7.0/mods-available/swoole.ini
cd /etc/php/7.0/cli/conf.d/ && ln -s ../../mods-available/swoole.ini 20-swoole.ini
cd /etc/php/7.0/fpm/conf.d/ && ln -s ../../mods-available/swoole.ini 20-swoole.iniCopy to clipboardErrorCopied
WSL 环境下必须关闭 daemonize 选项
低于 17101 的 WSL,源码安装 configure 后需要修改 config.h 关闭 HAVE_SIGNALFD
https://hub.docker.com/r/phpswoole/swoole
这里是./configure 编译配置的额外参数,用于开启某些特性
--enable-openssl
启用 SSL 支持
使用操作系统提供的 libssl.so 动态连接库
--with-openssl-dir
启用 SSL 支持 并 指定 openssl 库的路径,需跟上路径参数: --with-openssl-dir=/opt/openssl/
--enable-http2
开启对 HTTP2 的支持
依赖 nghttp2 库,在 v4.3.0 后不再需要安装依赖,改为内置,但仍需要增加该编译参数来开启 http2 支持
如无历史原因不建议启用
--enable-mysqlnd
启用 mysqlnd 支持,启用 Coroutine\MySQL::escapse 方法。启用此参数后,PHP 必须有 mysqlnd 模块,否则会导致 Swoole 无法运行。
依赖 mysqlnd 模块
--enable-sockets
增加对 php 的 sockets 资源的支持。开启此参数,swoole_event_add 就可以添加 sockets 扩展创建的连接到 Swoole 的事件循环中。
Server 和 Client 的 getSocket() 方法也需要依赖此编译参数。
依赖 sockets 扩展,v4.3.2 后该参数的作用被削弱了,因为 Swoole 内置的 Coroutine\Socket 可以完成大部分事情
生产环境不可以启用
--enable-debug
打开调试模式。使用 gdb 跟踪需要在编译 Swoole 时增加此参数。
--enable-debug-log
打开内核 DEBUG 日志。(Swoole 版本 >= 4.2.0)
--enable-trace-log
打开追踪日志,开启此选项后 swoole 将打印各类细节的调试日志,仅内核开发时使用
--enable-swoole
静态编译 Swoole 扩展到 PHP 中
此选项是在编译 PHP 而不是 Swoole 时使用的