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線程不會接受任何信號。
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com