Swoole修炼之路
Swoole 是什么
Swoole 是一个为 PHP 用 C 和 C++ 编写的基于事件的高性能异步&协程并行网络通信引擎
同步
1 | $data = file_get_contents('./data.json'); |
这个是常见的文件读取操作,在 file_get_contents 函数从磁盘上拿回文件数据前,代码不会继续运行,而是等待返回,因为后续的打印数据依赖上一条指令的返回值,这就是常见的同步编程
异步
Jqury 的 ajax
1 | $.ajax({ |
这段代码在运行到 ajax 的时候,函数会直接返回,马上就可以看到打印出来的 hello
这就是异步,不会遇到 IO 阻塞,但是它也带来了新的问题,当运行到 hello 的时候,我们必须等待 ajax 的回调被触发,然后看到打印出相应的数据。它的执行不是单行顺序的,而是嵌套的
当业务需求越来越复杂的时候,这样的嵌套可读性极差
Swoole 可以做什么
异步多线程协程服务器及客户端
异步 MySQL、Redis、数据库连接池、任务队列
HTTP、websocket 服务器/客户端
异步文件读写
部署 php-swoole
安装方式参考官网,这里使用 docker 部署安装
docker 官方镜像:https://hub.docker.com/r/phpswoole/swoole
1 | docker pull phpswoole/swoole |
启动 swoole 容器
1 | # 命令详解 |
测试
在宿主机 /var/web/swoole
目录下新建 server.php
TCP 服务器
1 | //创建Server对象,监听9501端口 |
这样就创建了一个 TCP
服务器,监听本机 9501
端口。它的逻辑很简单,当客户端 Socket
通过网络发送一个 hello
字符串时,服务器会回复一个 Server: hello
字符串。
Server
是异步服务器,所以是通过监听事件的方式来编写程序的。当对应的事件发生时底层会主动回调指定的函数。如当有新的 TCP
连接进入时会执行 onConnect 事件回调,当某个连接向服务器发送数据时会回调 onReceive 函数。
- 服务器可以同时被成千上万个客户端连接,
$fd
就是客户端连接的唯一标识符 - 调用
$server->send()
方法向客户端连接发送数据,参数就是$fd
客户端标识符 - 调用
$server->close()
方法可以强制关闭某个客户端连接 - 客户端可能会主动断开连接,此时会触发 onClose 事件回调
无法连接到服务器的简单检测手段
- 在
Linux
下,使用netstat -an | grep 端口
,查看端口是否已经被打开处于Listening
状态 - 上一步确认后,再检查防火墙问题
- 注意服务器所使用的 IP 地址,如果是
127.0.0.1
回环地址,则客户端只能使用127.0.0.1
才能连接上 - 用的阿里云服务或者腾讯服务,需要在安全权限组进行设置开发的端口