Swoole v6 正式发布,增加了 16 项新功能,主要如下:
- 多线程支持 :支持类似 NodeJS Workers Thread 的真正多线程,基于 PHP ZTS 实现,使用简单且无数据竞争问题。提供
Swoole\Thread类用于创建线程,在线程中可使用协程 API 实现异步非阻塞 IO。 - 多线程服务器 :服务器端模块适配多线程,提供
SWOOLE_THREAD模式,Event Worker、Task Worker 以及 User Worker 改为创建线程执行,工作线程间可传递ArrayList和Map等资源共享数据。 - 新增线程安全数据容器 :提供
ArrayList、Map、Queue3 种数据容器。ArrayList、Map实现ArrayAccess接口可当 PHP 数组用,Queue是先进先出队列可作线程间消息通信容器。容器支持多维嵌套,且是线程安全的,读写操作底层自动加锁。 - 新增线程同步工具 :包括
Swoole\Thread\Lock、Swoole\Thread\Atomic、Swoole\Thread\Barrier等,还提供Thread::join()、Thread::joinable()、Thread::detach()等方法用于线程管理和同步。 - 文件异步操作优化 :文件异步操作支持使用
io_uring作为底层引擎,安装liburing并在编译 Swoole 时开启--enable-iouring,相关文件操作函数的异步操作将由io_uring实现,且io_uring支持多线程轮询模式ioring_setup_sqpoll。 - 协程支持优化 :升级
boostcontext版本到 1.84,龙芯 CPU 也能够支持协程。 - 新增数据容器方法 :新增
Swoole\Thread\Map::find()、Swoole\Thread\ArrayList::find()、Swoole\Thread\ArrayList::offsetunset()方法。 - 新增进程和线程方法 :新增
Swoole\process::getaffinity()、Swoole\Thread::setname()、Swoole\Thread::setaffinity()、Swoole\Thread::getaffinity()、Swoole\Thread::setpriority()、Swoole\Thread::getpriority()、Swoole\Thread::gettid()方法。 - 新增 Iouring 配置相关 :新增
iouring_workers修改iouring线程数,新增iouring_flags支持修改iouring工作模式。 - 新增多线程同步屏障 :增加
Swoole\Thread\Barrier多线程同步屏障。 - 新增设置 Cookie 函数:增加新的设置 Cookie 的函数。
- 新增互斥协程锁:新增 "非阻塞,可重入的互斥协程锁",可在进程间 / 线程间使用,且不阻塞进程 / 线程。
- Socket 优化 :
Swoole\coroutine\socket::getoption()支持tcp_info选项。 - 客户端优化 :
Swoole\client同步阻塞客户端支持 http 代理,新增异步非阻塞的 tcp/udp/unix socket 客户端Swoole\async\client。 - Redis 服务器优化 :优化
Swoole\redis\server::format()方法,支持内存零拷贝,支持 redis 嵌套结构。 - 支持高性能压缩工具 :支持高性能压缩工具
zstd,编译 Swoole 时加上--enable-zstd,http 客户端和服务端之间便可使用zstd来压缩响应或者解码响应。