gateway中这样使用mysql正确么

程序gg了

start_gateway.php代码:

<?php 
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("tcp://0.0.0.0:8282");
$gateway = new Gateway("websocket://0.0.0.0:2000");
// gateway名称,status方便查看
$gateway->name = 'Device';
// gateway进程数
$gateway->count = 1;
// 本机ip,分布式部署时使用内网ip
$gateway->lanIp = '127.0.0.1';
// 内部通讯起始端口,假如$gateway->count=4,起始端口为4000
// 则一般会使用4000 4001 4002 4003 4个端口作为内部通讯端口 
$gateway->startPort = 2900;
// 服务注册地址
$gateway->registerAddress = '127.0.0.1:1238';

// 心跳间隔
$gateway->pingInterval = 10;
$gateway->pingNotResponseLimit = 1;
// 心跳数据
//$gateway->pingData = '{"type":"ping"}';
$gateway->pingData = '';

$db = new \Workerman\MySQL\Connection('host', '3306', 'username', 'password', 'dbName');

// 当客户端连接上来时,设置连接的onWebSocketConnect,即在websocket握手时的回调
$gateway->onConnect = function($connection)
{
    $connection->onWebSocketConnect = function($connection , $http_header)
    {
        global $db;
        // $_SERVER 可用这里判断连接来源是否合法,不合法就关掉连接
        try
        {
            // 查询数据库设备Token是否存在
            // 查询数据库设备Token是否存在
            // 查询数据库设备Token是否存在
            // 查询数据库设备Token是否存在
            // 查询数据库设备Token是否存在
            // 查询数据库设备Token是否存在
        }
        catch (\Exception $e)
        {
            echo $e->getMessage();
            $connection->close();
        }
    };
}; 

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

events.php 代码

<?php
/**
 * 用于检测业务代码死循环或者长时间阻塞等问题
 * 如果发现业务卡死,可以将下面declare打开(去掉//注释),并执行php start.php reload
 * 然后观察一段时间workerman.log看是否有process_timeout异常
 */
//declare(ticks=1);

use \GatewayWorker\Lib\Gateway;
use Workerman\Worker;
class Events
{
    public static $db = null;

    public static function onWorkerStart($worker)
    {
        self::$db = new \Workerman\MySQL\Connection('host', '3306', 'username', 'password', 'dbName');
    }

    // 当客户端连接时触发
    public static function onConnect($client_id)
    {
        // 向当前client_id发送数据
        Gateway::sendToClient($client_id, "Hello $client_id\r\n");
        // 向所有人发送
        Gateway::sendToAll("$client_id login\r\n");
    }

    // 当客户端发来消息时触发
    public static function onMessage($client_id, $message)
    {
        // 设置workerman处理一定请求后重启当前进程
        static $request_count;
        if(++$request_count > 100)
        {
            // 请求数达到10000后退出当前进程,主进程会自动重启一个新的进程
            Worker::stopAll();
        }

    }

    // 当用户断开连接时触发
    public static function onClose($client_id)
    {
        echo $client_id.'断开了'.PHP_EOL;
    }
}

两个页面都需要查询数据库

2248 1 0
1个回答

walkor

初始化数据库应该放到gateway->onWorkerStart里。不能在主进程直接初始化。
这样初始化

$gateway->onWorkerStart = function(){
    global $db;
    $db = new \Workerman\MySQL\Connection('host', '3306', 'username', 'password', 'dbName');
};
  • 暂无评论
年代过于久远,无法发表回答
🔝