最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

swoole用什么协议

来源:懂视网 责编:小采 时间:2020-11-03 18:23:42
文档

swoole用什么协议

swoole用什么协议:TCP是一个流式的协议,客户端向服务器发送一段数据后,可能并不会被服务器一次就完整的接收到。客户端向服务器发送多段数据,可能服务器一次就接收到了全部。 (推荐学习: swoole视频教程)在实际应用中,希望在服务器上能够一次接收一段完整的数据,不多也
推荐度:
导读swoole用什么协议:TCP是一个流式的协议,客户端向服务器发送一段数据后,可能并不会被服务器一次就完整的接收到。客户端向服务器发送多段数据,可能服务器一次就接收到了全部。 (推荐学习: swoole视频教程)在实际应用中,希望在服务器上能够一次接收一段完整的数据,不多也

TCP是一个流式的协议,客户端向服务器发送一段数据后,可能并不会被服务器一次就完整的接收到。客户端向服务器发送多段数据,可能服务器一次就接收到了全部。 (推荐学习: swoole视频教程)

在实际应用中,希望在服务器上能够一次接收一段完整的数据,不多也不少。

传统的TCP服务器中,往往需要由程序员维护一个缓存区,先将读取到数据写入缓存区,然后再通过预先设定好的协议内容来区分一段完整数据的开头、结尾和长度,并将一段完整的数据交给逻辑部分处理,这就是自定义协议的功能。

在Swoole中已经在底层实现了一个数据缓存区,并内置了几种常用的协议类型,并直接在底层做好了数据的拆分,以保证在onReceive回调函数中,一定能够收到一个或数个完整的数据段。

数据缓存区的大小可以通过配置pakcage_max_length来控制。

$configs = [];
$configs["package_max_length"] = 8192;
$server->set($configs);

swoole目前支持两种通讯协议:EOF结束符协议、固定包头加包体协议

package_max_length

package_max_length用于设置最大数据包尺寸,当开启open_length_check或open_eof_check或open_http_protocol等协议解析后,Swoole底层会进程数据包拼接,此时在数据包未收取完整时,所有数据都将保存在内存中。

所以需要设置package_max_length一个数据包最大允许占用的内存尺寸。

如果同时有1万个TCP连接在发送数据,每个数据包2MB,在最极端的情况下会占用20GB的内存空间。所以此参数不宜设置过大,否则会占用很大的内存。

相关配置选项

open_length_check

当发现数据包长度超过package_max_length时会直接丢弃此数据并关闭连接,因此不会占用任何内存,适用于websocket、mqtt、http2协议。

open_eof_check

由于无法事先得知数据包的长度,所以接收到的数据还是会保存在内存中持续增长。当发现内存占用已经超过package_max_length时,将直接丢地此数据包并关闭连接。

open_http_protocol

HTTP的GET请求最大允许8KB数据且无法修改此配置,POST请求会检测Content-Type,如果发现超过package_max_length则直接丢地此数据,并发送HTTP 400错误并关闭连接。

EOF协议

使用一组固定的、不会在正常数据内出现的字符串/r/n作为分割协议的标记,称之为EOF协议。

什么是EOF协议呢?

EOF全称 End of File,使用 作为结束标记。

在逐个读取数据流中的数据时,如果发现读到EOF标记,就表示已经读到数据末尾。

在TCP的数据流中,使用EOF协议的数据流的特征是|数据|EOF|数据|EOF|。

EOF协议处理的原理是在每串正常数据的末尾会添加一个预先规定的且绝对不会再数据中出现的字符串作为结束标记,这样接收到的数据就可以根据EOF标记来切分数据。

典型的memcached、ftp、stmp都是使用/r/n作为结束符。当发送数据时只要在数据包的末尾添加/r/n即可。

使用EOF协议处理一定要确保数据包中间不会出现EOF,否则将会造成分包错误。

swoole-7.gif

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

swoole用什么协议

swoole用什么协议:TCP是一个流式的协议,客户端向服务器发送一段数据后,可能并不会被服务器一次就完整的接收到。客户端向服务器发送多段数据,可能服务器一次就接收到了全部。 (推荐学习: swoole视频教程)在实际应用中,希望在服务器上能够一次接收一段完整的数据,不多也
推荐度:
标签: 使用 协议 的协议
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top