workerMan之心跳检测

薄洪涛6年前PHP1413

上次咱们说到,长连接应用必须加心跳检测,避免连接由于上时间没有通讯被断开

其实心跳的作用有2个:

1、客户端定时给服务器发送数据,防止连接由于长时间没有通讯被断开

2、服务端可以通过心跳来判断客户端是否在线(由于断网,断电等情况客户端无法完成断开的四次握手,服务器不知道客户端是否还在线)


workerMan心跳示例

<?php
/**
 * Created by PhpStorm.
 * User: John
 * Date: 2019/4/9
 * Time: 13:36
 */

require_once __DIR__ . '/../Workerman-framework/Autoloader.php';
use Workerman\Worker;
use Workerman\Lib\Timer;

// 心跳间隔55秒
define('HEARTBEAT_TIME', 10);

$worker = new Worker('websocket://0.0.0.0:1234');
//收到消息回调
$worker->onMessage = function($connection, $msg) {
    // 给connection临时设置一个lastMessageTime属性,用来记录上次收到消息的时间
    $connection->lastMessageTime = time();
    $connection->send("get massage".$msg);
};

// 进程启动后设置一个每秒运行一次的定时器
$worker->onWorkerStart = function($worker) {
    Timer::add(1, function()use($worker){
        $time_now = time();
        foreach($worker->connections as $connection) {
            // 有可能该connection还没收到过消息,则lastMessageTime设置为当前时间
            if (empty($connection->lastMessageTime)||!isset($connection->lastMessageTime)) {
                $connection->lastMessageTime = $time_now;
                continue;
            }
            // 上次通讯时间间隔大于心跳间隔,则认为客户端已经下线,关闭连接
            if ($time_now - $connection->lastMessageTime > HEARTBEAT_TIME) {
                $connection->send("close connection");
                $connection->close();
            }
        }
    });
};

Worker::runAll();

前端请求

ws = new WebSocket("ws://127.0.0.1:1234");
ws.onopen = function() {
    ws.send('tom');
};
ws.onmessage = function(e) {
    console.log(e.data)
};

TIM截图20190409140148.png


我们可以看到在客户端连接到服务器后,10秒内没有发送数据,服务器自动关闭了连接

标签: 心跳

相关文章

PostgreSQL教程之安装连接

PostgreSQL教程之安装连接

新公司需要用PostgreSQL数据库,而且网上的资料比较少,先自己整理一下;一、PostgreSQL是什么?PostgreSQL是一个功能强大的开源对象关系数据库管理系统(ORDBMS)。 用于安全...

Yii2.0 jQuery(...).yiiActiveForm is not a function

Yii2.0 jQuery(...).yiiActiveForm is not a function

记一个常见的错误,如下图当我们在view中创建一个activeForm的时候,有时会报这种错误;通常情况下,是jquery重复引入导致的,因为你引入的jquey的版本跟yii2自带jquery版本冲突...

Yii2使用phpOffice导出excel报错

Yii2使用phpOffice导出excel报错

线上导出excel的时候,是不是出现无法访问,如下图因为导出的数据量比较大,我怀疑是内存溢出,于是增加了内存分配值,发现仍然报错,于是我查了下日志,如下2020-08-14 21:31:12...

[Err] 1071 - Specified key was too long; max key length is 767 bytes

做数据库sql导入的时候,报错,[Err] 1071 - Specified key was too long; max key length is 767 bytes修正方法set glo...

Elasticsearch为什么搜索那么快?

Elasticsearch为什么搜索那么快?

介绍Elasticsearch 是一个分布式可扩展的实时搜索和分析引擎,一个建立在全文搜索引擎 Apache Lucene(TM) 基础上的搜索引擎.当然 Elasticsearch 并不仅仅是 Lu...

五十个小技巧提高PHP执行效率

    在项目开发过程中,经常遇到了一些PHP处理程序性能底下的情况,程序运行在centos+nginx环境,虽然这个有很多的原因如:服务器本身配置,运行环境n...

评论列表

访客
2019-04-12 17:58:45

踩踩

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。