原创

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

温馨提示:
本文最后更新于 2019年01月07日,已超过 1,935 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我

最近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该反思的

正文到此结束
本文目录