AsyncIO

1.6.12版本增加了异步文件读写,异步DNS,异步Http/WebSocket客户端等特性。开发纯异步非阻塞IO的程序时,不能使用PHP自带的网络客户端,如curlfile_get_contentsstreamsocketsmysqlredis

  • Swoole\ServerTask进程是同步阻塞的,没有EventLoop,因此无法使用除定时器之外的任何异步API
  • signalfdLinux-2.6.27提供文件句柄方式处理信号特性,优点是可以将信号加入到EventLoop中,Reactor操作不会被信号打断提高了性能。缺点是有些同步阻塞的程序可能会出现问题,无法从阻塞中中断,可以使用swoole_async_set关闭signalfd特性

swoole_async_set

此函数可以设置异步IO相关的选项。

swoole_async_set(array $setting);
  • thread_num 设置异步文件IO线程的数量
  • aio_mode 设置异步文件IO的操作模式,目前支持SWOOLE_AIO_BASE(使用类似于Node.js的线程池同步阻塞模拟异步)、SWOOLE_AIO_LINUX(Linux Native AIO) 2种模式
  • enable_signalfd 开启和关闭signalfd特性的使用
  • socket_buffer_size 设置SOCKET内存缓存区尺寸
  • socket_dontwait 在内存缓存区已满的情况下禁止底层阻塞等待
  • log_file 设置日志文件路径
  • log_level 设置错误日志等级

Linux Native AIO的优点是由内核支持是真正的异步文件IO,缺点是只支持DirectIO,无法利用到系统的PageCache


  • 飞鸿影

    swoole异步就是为了解决这个问题,当你的程序读取网络或磁盘时。swoole会加入到事件监听中,完全不需要等待,你的代码可以取做别的事情。当网络或磁盘读取完成,返回数据时,再继续向下执行你的代码。这样就可以高效利用机器资源。再高的并发也不是问题。 https://group.swoole.com/question/105709

  • 飞鸿影

    swoole_http_client::get(): async-io must be used in PHP CLI mode