安装Swoole教程

时间:2023年05月17日

/

来源:网络

/

编辑:佚名

安装 Swoole
Swoole 扩展是按照 PHP 标准扩展构建的。使用 phpize 来生成编译检测脚本,./configure 来做编译配置检测,make 进行编译,make install 进行安装。
如无特殊需求,请务必编译安装 Swoole 的最新 Swoole5.0.2 版本或 Swoole4.8.13。
如果当前用户不是 root,可能没有 PHP 安装目录的写权限,安装时需要 sudo 或者 su。
如果是在 git 分支上直接 git pull 更新代码,重新编译前务必要执行 make clean。
仅支持 Linux(2.3.32 以上内核)、FreeBSD、MacOS 三种操作系统。
低版本 Linux 系统(如 CentOS 6)可以使用 RedHat 提供的 devtools 编译,参考文档 。
在 Windows 平台,可使用 WSL(Windows Subsystem for Linux) 或 CygWin。
部分扩展与 Swoole 扩展不兼容,参考扩展冲突。
安装准备
安装前必须保证系统已经安装了下列软件
4.8 版本需要 php-7.2 或更高版本
5.0 版本需要 php-8.0 或更高版本
gcc-4.8 或更高版本
make
autoconf
快速安装
1. 下载 swoole 源码
https://github.com/swoole/swoole-src/releases
https://pecl.php.net/package/swoole
https://gitee.com/swoole/swoole/tags
2. 从源码编译安装
下载源代码包后,在终端进入源码目录,执行下面的命令进行编译和安装
ubuntu 没有安装 phpize 可执行命令:sudo apt-get install php-dev 来安装 phpize
cd swoole-src && \
phpize && \
./configure && \
sudo make && sudo make install
Copy 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-sockets --enable-mysqlnd --enable-swoole-curl --enable-cares --enable-swoole-pgsql && \
sudo make && sudo make install
Copy to clipboardErrorCopied
PECL
注意: PECL 发布时间晚于 GitHub 发布时间
Swoole 项目已收录到 PHP 官方扩展库,除了手动下载编译外,还可以通过 PHP 官方提供的 pecl 命令,一键下载安装
pecl install swoole
Copy to clipboardErrorCopied
通过 PECL 安装 Swoole 时,在安装过程中它会询问是否要启用某些功能,这也可以在运行安装之前提供,例如:
pecl install -D 'enable-sockets="no" enable-openssl="yes" enable-http2="yes" enable-mysqlnd="yes" enable-swoole-json="no" enable-swoole-curl="yes" enable-cares="yes"' swoole
#或者
pecl install --configureoptions 'enable-sockets="no" enable-openssl="yes" enable-http2="yes" enable-mysqlnd="yes" enable-swoole-json="no" enable-swoole-curl="yes" enable-cares="yes"' swoole
Copy to clipboardErrorCopied
添加 Swoole 到 php.ini
最后,编译安装成功后,修改 php.ini 加入
extension=swoole.so
Copy 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.ini
Copy to clipboardErrorCopied
WSL 环境下必须关闭 daemonize 选项
低于 17101 的 WSL,源码安装 configure 后需要修改 config.h 关闭 HAVE_SIGNALFD
Docker 官方镜像
GitHub: https://github.com/swoole/docker-swoole
dockerhub: 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 支持,Swoole5 默认启用该参数。
--enable-swoole-json
启用对 swoole_substr_json_decode 的支持,Swoole5 开始默认启用该参数
依赖 json 扩展,v4.5.7 版本可用
--enable-swoole-curl
启用对 SWOOLE_HOOK_NATIVE_CURL 的支持
v4.6.0 版本可用。如果编译报错 curl/curl.h: No such file or directory,请查看安装问题
--enable-cares
启用对 c-ares 的支持
依赖 c-ares 库,v4.7.0 版本可用。如果编译报错 ares.h: No such file or directory,请查看安装问题
--with-jemalloc-dir
启用对 jemalloc 的支持
--enable-brotli
启用对 libbrotli 压缩支持
--with-brotli-dir
启用 libbrotli 压缩支持并指定 libbrotli 库的路径,需跟上路径参数,如: --with-brotli-dir=/opt/brotli/
特殊参数
如无历史原因不建议启用
--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 可以完成大部分事情
Debug 参数
生产环境不可以启用
--enable-debug
打开调试模式。使用 gdb 跟踪需要在编译 Swoole 时增加此参数。
--enable-debug-log
打开内核 DEBUG 日志。(Swoole 版本 >= 4.2.0)
--enable-trace-log
打开追踪日志,开启此选项后 swoole 将打印各类细节的调试日志,仅内核开发时使用
--enable-swoole-coro-time
启用对协程运行时间计算,此选项开启后,可以使用 Swoole\Coroutine::getExecuteTime () 计算协程执行时间,不包括 I\O 等待时间。
PHP 编译参数
--enable-swoole
静态编译 Swoole 扩展到 PHP 中,根据下面的操作,就能出现 --enable-swoole 这个选项。
cp -r /home/swoole-src /home/php-src/ext
cd /home/php-src
./buildconf --force
./configure --help | grep swoole
Copy to clipboardErrorCopied
此选项是在编译 PHP 而不是 Swoole 时使用的
猜你需要

豫ICP备2021026617号-1  豫公网安备:41172602000185   Copyright © 2021-2028 www.78moban.com/ All Rights Reserved

本站作品均来自互联网,转载目的在于传递更多信息,并不代表本站赞同其观点和对其真实性负责。如有侵犯您的版权,请联系 1565229909#qq.com(把#改成@),我们将立即处理。