Swoole v6 正式发布

Swoole v6 正式发布,增加了 16 项新功能,主要如下:

  1. 多线程支持 :支持类似 NodeJS Workers Thread 的真正多线程,基于 PHP ZTS 实现,使用简单且无数据竞争问题。提供Swoole\Thread类用于创建线程,在线程中可使用协程 API 实现异步非阻塞 IO。
  2. 多线程服务器 :服务器端模块适配多线程,提供SWOOLE_THREAD模式,Event Worker、Task Worker 以及 User Worker 改为创建线程执行,工作线程间可传递ArrayListMap等资源共享数据。
  3. 新增线程安全数据容器 :提供ArrayListMapQueue 3 种数据容器。ArrayListMap实现ArrayAccess接口可当 PHP 数组用,Queue是先进先出队列可作线程间消息通信容器。容器支持多维嵌套,且是线程安全的,读写操作底层自动加锁。
  4. 新增线程同步工具 :包括Swoole\Thread\LockSwoole\Thread\AtomicSwoole\Thread\Barrier等,还提供Thread::join()Thread::joinable()Thread::detach()等方法用于线程管理和同步。
  5. 文件异步操作优化 :文件异步操作支持使用io_uring作为底层引擎,安装liburing并在编译 Swoole 时开启--enable-iouring,相关文件操作函数的异步操作将由io_uring实现,且io_uring支持多线程轮询模式ioring_setup_sqpoll
  6. 协程支持优化 :升级boostcontext版本到 1.84,龙芯 CPU 也能够支持协程。
  7. 新增数据容器方法 :新增Swoole\Thread\Map::find()Swoole\Thread\ArrayList::find()Swoole\Thread\ArrayList::offsetunset()方法。
  8. 新增进程和线程方法 :新增Swoole\process::getaffinity()Swoole\Thread::setname()Swoole\Thread::setaffinity()Swoole\Thread::getaffinity()Swoole\Thread::setpriority()Swoole\Thread::getpriority()Swoole\Thread::gettid()方法。
  9. 新增 Iouring 配置相关 :新增iouring_workers修改iouring线程数,新增iouring_flags支持修改iouring工作模式。
  10. 新增多线程同步屏障 :增加Swoole\Thread\Barrier多线程同步屏障。
  11. 新增设置 Cookie 函数:增加新的设置 Cookie 的函数。
  12. 新增互斥协程锁:新增 "非阻塞,可重入的互斥协程锁",可在进程间 / 线程间使用,且不阻塞进程 / 线程。
  13. Socket 优化Swoole\coroutine\socket::getoption()支持tcp_info选项。
  14. 客户端优化Swoole\client同步阻塞客户端支持 http 代理,新增异步非阻塞的 tcp/udp/unix socket 客户端Swoole\async\client
  15. Redis 服务器优化 :优化Swoole\redis\server::format()方法,支持内存零拷贝,支持 redis 嵌套结构。
  16. 支持高性能压缩工具 :支持高性能压缩工具zstd,编译 Swoole 时加上--enable-zstd,http 客户端和服务端之间便可使用zstd来压缩响应或者解码响应。
相关推荐
aqi008 分钟前
FFmpeg开发笔记(一百零二)国产的音视频移动开源工具FFmpegAndroid
android·ffmpeg·kotlin·音视频·直播·流媒体
星间都市山脉21 分钟前
Android 谷歌 CTS 完整测试
android
nianniannnn29 分钟前
快应用day2项目架构
android·快应用
用户83352502537852 小时前
ViewModel详细解析
android
问心无愧05132 小时前
ctf show web入门91
android·前端·笔记
YF02112 小时前
Android App 高效升级指南:OkDownload 多线程断点续传与全版本安装适配
android·okhttp·app
huangliang07032 小时前
MySQL 中的 distinct 和 group by 哪个效率更高?
android·数据库·mysql
程思扬2 小时前
Android 悬浮窗状态错乱终极解决方案:告别 onResume
android·网络
逸Y 仙X2 小时前
文章二十九:ElasticSearch分桶聚合
android·大数据·elasticsearch·搜索引擎·全文检索
陆业聪2 小时前
网络监控与容灾:让网络问题无处遁形
android·性能优化·启动优化