[Swoole系列入门教程 3] 心跳检测
一.Swoole 的4大知识点:
1.TCP/UDP服务器
2.微服务
3.协程
二.同步与异步:
同步买奶茶:小明点单交钱,然后等着拿奶茶;
异步买奶茶:小明点单交钱,店员给小明一个小票,等小明奶茶做好了,再来取。
差别:发送消息和接受消息不是同步的!
发送API请求, 和获取API请求的结果不是同步的!GPS平台可用
所以用到的可能是swoole的异步client! 不过4.3之后,异步客户端的recv方法被移除了
异步客户端(4.3之后是协程客户端?)是长链接, 不是连了就断了,但是oneLink服务器的不一定是长链接
三.长链接和短连接
短连接:例如ajax(HTTP), 链接完就断了,只能客户端主动发消息给服务端
使用ajax模拟长链接的话, 轮询, 不断的去请求服务器, 不断的创建-销毁链接, 对服务器压力非常大
长链接: 服务端也能够发消息给客户端(TCP)
长链接可能存在的问题: 链接断开 ->引入心跳检测概念
四:心跳检测
分布式组件(心跳包):
1.能够剔除一些无用的链接(例如webSocket关闭浏览器却没有关闭链接)
2.保持活跃(长期没有发消息,类似QQ的敲门提示)
3.网络传输过程中没了
为什么要心跳检测?
1.通过心跳检测,回收fd,因为fd资源是有限的
2.客户端定时给服务端发送点数据,防止连接由于长时间没有通讯而被某些节点
的防火墙关闭导致连接断开的情况。
3.服务端可以通过心跳来判断客户端是否在线,如果客户端在规定时间内没有发来任何数据,
就认为客户端下线。这样可以检测到客户端由于极端情况(断电、断网等)下线的事件。
五.swoole心跳检测的代码实现
$server->set([
'worker_num'=>1, //设置进程
'heartbeat_idle_time'=>10,//连接最大的空闲时间
'heartbeat_check_interval'=>3 //服务器定时检查
]);
六.定时器(Timer)
demo测试方法, 写个定时器, 再差不多到空闲时间, 客户端就发送一个消息,用于保持连接
[Swoole系列入门教程 3] 心跳检测的更多相关文章
- [Swoole系列入门教程 5] UDP协议和demo
• 客户端服务端没有任何联系 • 指定地址跟端口,不关心消息是否发送成功 • 心跳检测不能影响到客户端• udp建立长连接
- [Swoole系列入门教程 4] 定时器与心跳demo
- [Swoole系列入门教程 1] CentOs 上的Swoole安装
如果已经用宝塔安装好了PHP, 开启相应的扩展 一.编译安装git clone https://github.com/swoole/swoole-src.git cd swoole-src/ phpi ...
- [Swoole系列入门教程 6] TCP协议和粘包
- [Swoole系列入门教程 2] 入门级的Swoole的demo.服务端与客户端
- Laravel 5 系列入门教程(一)【最适合中国人的 Laravel 教程】
Laravel 5 系列入门教程(一)[最适合中国人的 Laravel 教程] 分享⋅ johnlui⋅ 于 2年前 ⋅ 最后回复由 skys215于 11个月前 ⋅ 17543 阅读 原文发表在 ...
- 2016 版 Laravel 系列入门教程
2016 版 Laravel 系列入门教程 (1) - (5) http://www.golaravel.com/post/2016-ban-laravel-xi-lie-ru-men-jiao-ch ...
- Mina 系列(四)之KeepAliveFilter -- 心跳检测
Mina 系列(四)之KeepAliveFilter -- 心跳检测 摘要: 心跳协议,对基于CS模式的系统开发来说是一种比较常见与有效的连接检测方式,最近在用MINA框架,原本自己写了一个心跳协议实 ...
- 《进击吧!Blazor!》系列入门教程 第一章 8.部署
<进击吧!Blazor!>是本人与张善友老师合作的Blazor零基础入门教程视频,此教程能让一个从未接触过Blazor的程序员掌握开发Blazor应用的能力. 视频地址:https://s ...
随机推荐
- layui中的tab切换
tab切换是常见的效果,为了方便经常使用插架中自带的,下面是layui中自带的tab切换效果, 主要代码如下: <!DOCTYPE html> <html lang="en ...
- QQ聊天机器人 Delphi代码
QQ聊天机器人 前几日,看到杂志上有一篇关于开发QQ聊天机器人的文章.谈到了对QQ循环发送消息内容,感觉倒也很好玩,于是拿起Delphi开始了我的QQ聊天机器人之路. 首先要明白自己要做什么, ...
- el-upload文件上传组件
一.介绍 element-ui的组件之一,用来点击上传文件 官方是使用 before-upload 限制用户上传的图片格式和大小.但是某些浏览器不支持此方法,所以使用on-change来代替. 二.代 ...
- C++函数调用原理理解
空程序: int main() { 00411360 push ebp ;压入ebp 00411361 mov ebp,esp ;ebp = es ...
- VS2010-MFC(MFC常用类:CTime类和CTimeSpan类)
转自:http://www.jizhuomi.com/software/230.html 上一节讲了MFC常用类CString类的用法,本节继续讲另外两个MFC常用类-日期和时间类CTime类和CTi ...
- System.IO.Directory.cs
ylbtech-System.IO.Directory.cs 1.返回顶部 1. #region 程序集 mscorlib, Version=4.0.0.0, Culture=neutral, Pub ...
- vue 绑定多个class
<div :class="[box,shadow]"></div> 或 :后面跟条件,条件成立则添加class,否则不添加 :class="[{' ...
- 20.multi_case02
# 多进程,使用Process对象 from multiprocessing import Process def f(name): print('hello', name) if __name__ ...
- python语句结构(while循环)
while循环 pythhon中while语句的一般形式 while 判断语句: 执行语句 i=0 sum=0 while i<=100: sum+=i i=i+1 print(sum) #运行 ...
- java_序列化
import java.io.*; class People implements Serializable { /* * 序列化和反序列化的时候,会抛出就NotSerializableExcepti ...