33

Swoole 多协议 多端口 的应用

 5 years ago
source link: http://mp.weixin.qq.com/s?__biz=MjM5NDM4MDIwNw%3D%3D&%3Bmid=2448835038&%3Bidx=1&%3Bsn=9aa1dd1c76fbdfdae1c110f411c3f9e3&%3Butm_source=tuicool&%3Butm_medium=referral
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

第 81 篇文章

这是关于 Swoole 学习的第五篇文章:Swoole 多协议 多端口 的应用。

概述

主要参考官方的这两篇文章,进行实现的 Demo。

  • 网络通信协议设计:

    https://wiki.swoole.com/wiki/page/484.html

  • 多端口监听的使用:

    https://wiki.swoole.com/wiki/page/161.html

希望通过我提供的 Demo,能够对文档有更加深刻的理解。

网络通信协议设计

为什么需要通信协议?

官方:TCP协议在底层机制上解决了UDP协议的顺序和丢包重传问题。但相比UDP又带来了新的问题,TCP协议是流式的,数据包没有边界。应用程序使用TCP通信就会面临这些难题。因为TCP通信是流式的,在接收1个大数据包时,可能会被拆分成多个数据包发送。多次Send底层也可能会合并成一次进行发送。这里就需要2个操作来解决:分包 和 合包,所以TCP网络通信时需要设定通信协议。

Swoole 支持了2种类型的自定义网络通信协议 :EOF结束符协议、固定包头+包体协议。

EOF结束符协议

BFNJzaB.png!web

先看下,未设置协议的效果:

QB7fQbf.gif

发送的每条数据长度都是 23,但在 onReceive 接收数据的时候每次接收的长度不一样,并没有按照想象的方式进行分包。

再看下,设置了EOF结束符协议的效果:

JVFRZba.gif

发送的每条数据长度都是 23,在 onReceive 接收数据的时候每次接收的也是 23 ,完美。

主要设置项如下:

不做解释,官方文档已经写的很清楚。

示例代码如下:

server.php

client.php

固定包头+包体协议

MNRrqur.png!web

先看下,未设置协议的效果:

yeeiimY.gif

很明显,在 onReceive 接收到的数据,是少的。

再看下,设置协议的效果:

ZJjMFja.gif

主要设置项如下:

不做解释,官方文档已经写的很清楚。

示例代码如下:

server.php

client.php

多端口监听的使用

yuEb6r6.jpg!web

上图,是示例代码中的端口监听:

  • 9501 onMessage 处理 WebSocket。

  • 9501 onRequest 处理 HTTP。

  • 9502 onReceive 处理 TCP。

  • 9503 onPacket 处理 UDP。

不多说,看下效果图:

Avu2aiV.gif

示例代码如下:

server.php

4 个客户端连接的代码分别是:

1、9501 onMessage 处理 WebSocket。可以参考原来文章 Swoole WebSocket 的应用 中的代码即可。

2、9501 onRequest 处理 HTTP。可以参考原来文章Swoole HTTP 的应用 中的代码即可。

3、9502 onReceive 处理 TCP。可以参考原来文章Swoole Task 的应用 中的代码即可。

4、9503 onPacket 处理 UDP。

示例代码:

小结

一、多端口的应用场景是什么?

比如,开发一个直播网站,直播用一个端口,IM聊天用一个端口。

比如,开发一个RPC服务,数据通讯用一个端口,统计界面用一个端口。


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK