视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
swoole解决了什么问题
2020-11-03 18:23:05 责编:小采
文档

php现有的应用方式都是基于http的,对于需要快速实时响应的情况比较乏力,比如网络游戏或者推送服务一般都需要与用户长期保持一个tcp连接以便实时响应和推送信息。

swoole就是解决这样应用场景的。 (推荐学习: swoole视频教程)

Swoole的实现

swoole使用纯C编写,不依赖其他第三方库。

swoole并没有用libevent,所以不需要安装libevent

swoole并不依赖php的stream/sockets/pcntl/posix/sysvmsg等扩展

socket部分

swoole使用底层的socket系统调用。

IO事件循环

主进程的事件循环使用select/poll,因为主线程中的文件描述符只有几个,使用select/poll即可

reactor线程/worker进程中使用epoll/kqueue

task进程没有事件循环,进程会循环阻塞读取管道

有很多人使用strace -p去查看swoole主进程只能看到poll系统调用。正确的查看方法是strace -f -p

多进程/多线程

多进程使用fork()系统调用

多线程使用pthread线程库

EventFd

Swoole中使用了eventfd作为线程/进程间消息通知的机制。

Timerfd

Swoole使用timerfd来实现定时器

SIgnalfd

swoole中使用了signalfd来实现对信号的屏蔽和处理。可以有效地避免线程/进程被信号打断,系统调用restart的问题。在主进程中reactor线程不会接受任何信号。

下载本文
显示全文
专题