关于使用php理论实现swoole扩展的功能

最近swoole在php中越来越知名,很多人说swoole给与了php的新生,有swoole的php可以和node js,go等语言抗衡,那么,我们从技术角度来说,swoole到底实现了什么,如果没有php,就实现不了协程,多进程等功能吗?
到底是php语言有问题?还是各大phper有问题?

swoole

首先我们了解下swoole究竟是什么东西:

PHP的协程高性能网络通信引擎,使用C/C++语言编写,提供了PHP语言的异步多线程服务器,异步TCP/UDP网络客户端,异步MySQL,异步Redis,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。 Swoole内置了Http/WebSocket服务器端/客户端、Http2.0服务器端/客户端。

根据swoole介绍,已经文档说明的功能,我将swoole大概实现的功能大致列出:

 1:tcp服务器,http服务器,websocket服务器,redis 服务器

 2:udp服务器

 3:协程管理,协程异步IO监听

 4:内存操作管理

 5:多进程管理,多进程通信,进程信号监听

 6:异步任务管理

 7:tcp,udp客户端

 8:http,http2,mysql,redis等协程客户端

 9:定时器

在后面,我们将一个个讲解,如何使用php实现功能.


tcp服务器/udp服务器

tcp/udp服务器其实php使用socket函数,即可创建一个tcp服务器了,我之前也写过类似文章:php实现socket网络编程

首先,我们从swoole实现tcp/udp的具体架构说起:

 tcp服务器模型

swoole官网图

仙士可博客

在php中,pcntl扩展可支持多进程,但是不支持多线程,我们如果需要实现的话,只能把线程改为进程,通过php进程通信-消息队列

进行进程通信

 I/O复用模型

swoole采用了4种I/O模型(epoll,kqueue,select,poll),根据操作系统的不同而选择不同的模型

在php中,我们可通过安装libevent扩展,socket_select函数等方法实现I/O复用


通过php的socket扩展+I/O复用可实现tcp服务器,再通过消息队列等进程通信方法,实现多进程的tcp服务器

 

tcp/udp服务器是swoole的核心,http,websocket等服务器都是基于tcp实现

难点:

1:多进程通信

2:I/O复用

3:tcp粘包处理

4:超时断线处理



http服务器

在上面,我们已经通过php实现了tcp服务器,http作为tcp的子协议,只要我们在tcp接收逻辑中,解析http头,进行响应的处理,并发送规定的http响应头即可


难点:

1:http协议非常多,只能做简单的get,post等协议解析,其他交给nginx服务器

2:解析post等数据


websocket服务器

websocket服务器继承http以及tcp,同样,只需要解析好握手时的协议头即可


难点:

1:websocket握手机制需要了解


协程

在协程方面,我们可直接通过yield实现协程php yield关键字以及协程的实现

难点:

1:封装一个完善的协程框架

2:需要增加一个异步I/O的监听管理,与协程管理通信,使其能够自动监听I/O完成,然后恢复协程


内存管理

关于内存管理方面,本人并不是很熟悉,只知道shmop扩展可实现php的共享内存


多进程

使用pcntl扩展可实现多进程,进程信号,通过pipe,消息队列等方法可实现进程通信


异步任务管理

通过pcntl创建异步task任务,然后worker进程通过进程通信将任务传递给task即可


tcp,udp客户端

通过socket扩展即可实现:http://www.php20.cn/article/162


协程客户端

大家都知道,mysql,redis等在php中通信都是基于tcp的,我们可通过tcp非阻塞客户端+通信协议实现异步的客户端


再通过协程的模块,实现yield并监听I/O,I/O到了之后恢复协程状态


定时器

通过pcntl_alarm 函数进行定时发起进程信号,再然后实现回调即可实现定时器



技术总结

由上面可知道,php是可基本实现swoole的大部分功能的,具体总结如下:

 1:多进程,进程通信方面,进程信号,pipe管道通信,消息队列,共享内存都可实现

 2:网络编程,socket扩展+libeventI/O复用即可实现

 3:协程,I/O自动切换协程,通过yield关键字,socket设置非阻塞,即可实现协程并在I/O耗时时切换协程

 4:异步任务可由1实现


总结

swoole通过php扩展实现,优势是非常大的,例如自动切换协程,内置函数的hook等.

写这篇文章只是想让自己,和大家更加了解swoole到底实现了什么,php到底是不是最好的语言(手动滑稽)

抛弃swoole,我们php本身内置的扩展已经可以让我们做很多事情,但是除了workerman,又有哪些知名的php socket框架呢?在swoole之前,为什么没人提起过协程化编程呢?这是我们作为phper该反思的







仙士可博客
请先登录后发表评论
  • 最新评论
  • 总共2条评论
仙士可博客

windrunner:牛逼啊

2019-01-17 22:43:27 回复

仙士可博客

x:牛逼啊

2019-01-07 12:00:34 回复

  • 本站由白俊遥博客程序搭建
    © 2017-1-17 php20.cn 版权所有 ICP证:闽ICP备17001387号
  • 联系邮箱:1067197739@qq.com