心跳没效果,但后端服务已经设置了心跳了。

1204604589@qq.com

问题描述

我客户端开始能链接上ws服务,但过几十秒样子,又断开了显示链接失败。应该是心跳没接成功。现在问题是我服务端已经加上了 心跳,怎么没起作用呐?

程序代码

<?php 
/**
 * This file is part of workerman.
 *
 * Licensed under The MIT License
 * For full copyright and license information, please see the MIT-LICENSE.txt
 * Redistributions of files must retain the above copyright notice.
 *
 * @author walkor<walkor@workerman.net>
 * @copyright walkor<walkor@workerman.net>
 * @link http://www.workerman.net/
 * @license http://www.opensource.org/licenses/mit-license.php MIT License
 */
use \Workerman\Worker;
use \Workerman\WebServer;
use \GatewayWorker\Gateway;
use \GatewayWorker\BusinessWorker;
use \Workerman\Autoloader;

// 自动加载类
require_once __DIR__ . '/../../vendor/autoload.php';

// gateway 进程,这里使用Text协议,可以用telnet测试
$gateway = new Gateway("websocket://0.0.0.0:8285");
// gateway名称,status方便查看
$gateway->name = 'AppGateway';
// gateway进程数
$gateway->count = 4;
// 本机ip,分布式部署时使用内网ip
$gateway->lanIp = '127.0.0.1';
// 内部通讯起始端口,假如$gateway->count=4,起始端口为4000
// 则一般会使用4000 4001 4002 4003 4个端口作为内部通讯端口 
$gateway->startPort = 4900;
// 服务注册地址
$gateway->registerAddress = '127.0.0.1:1238';

$gateway->pingInterval = 55;

$gateway->pingNotResponseLimit = 1;

// 服务端定时向客户端发送的数据
// $gateway->pingData = '{"type":"ping"}';
$gateway->pingData = '{"type":"hello"}';

// 当客户端连接上来时,设置连接的onWebSocketConnect,即在websocket握手时的回调
$gateway->onConnect = function($connection)
{
    $connection->onWebSocketConnect = function($connection , $http_header)
    {
        // 可以在这里判断连接来源是否合法,不合法就关掉连接
        // $_SERVER['HTTP_ORIGIN']标识来自哪个站点的页面发起的websocket链接
        if($_SERVER['HTTP_ORIGIN'] != 'http://kedou.workerman.net')
        {
            $connection->close();
        }
        // onWebSocketConnect 里面$_GET $_SERVER是可用的
        var_dump($_GET, $_SERVER);
    };
}; 

// 如果不是在根目录启动,则运行runAll方法
if(!defined('GLOBAL_START'))
{
    Worker::runAll();
}

截图报错信息里报错文件相关代码

截图
截图
截图

操作系统及workerman/webman等框架组件具体版本

linux


执行过 这个命令重启了
![截图](/upload/img/20230620/2064916c84ed8f.png)
698 1 0
1个回答

Gin

服务重启了吗

年代过于久远,无法发表回答
×
🔝