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