【问题标题】:Socket IO with REDIS. Server not getting channel message带有 REDIS 的套接字 IO。服务器没有收到频道消息
【发布时间】:2018-03-10 21:40:01
【问题描述】:

我失去了将近 2 天的谷歌搜索和搜索,试图找出我的设置有什么问题。 我所有的服务都在一个 Docker 容器中运行,所有的连接都正确(我已经测试过了)

我在连接到 Redis 的 Node.JS 上有一个最小的 Socket IO 服务器:

require('longjohn');
require('dotenv').load({silent: true});
process.env = process.env || {};

var PORT    = process.env.SOCKET_PORT || 4567;
var io      = require('socket.io').listen(PORT);
var redis   = require('socket.io-redis');

io.adapter(redis({
    host: process.env.REDIS_HOST || 'redis',
    port: process.env.REDIS_PORT || 6379
}));

io.on('connection', function (socket) {
    console.log(`New connection!`);
}

当我在 Redis 上监控这段代码时,我得到了:

1520713149.833184 [0 172.20.0.8:40858] "info"
1520713149.833631 [0 172.20.0.8:40860] "info"
1520713149.834154 [0 172.20.0.8:40862] "info"
1520713149.839510 [0 172.20.0.8:40860] "subscribe" "socket.io#/#"
1520713149.840678 [0 172.20.0.8:40862] "subscribe" "socket.io-sync#request#/#"

然后是一个连接并发送到 Redis 的 php 应用程序

<?php

require(__DIR__.'/vendor/autoload.php');

$client = new Predis\Client([
    'scheme' => 'tcp',
    'host'   => 'redis',
    'port'   => 6379,
]);

$client->connect();
$emitter = new SocketIO\Emitter($client);
$emitter->emit('event', 'payload str');

在 Redis 上:

"PUBLISH" "socket.io#emitter" "\x92\x83\xa4type\x02\xa4data\x92\xa5event\xabpayload str\xa3nsp\xa1/\x82\xa5rooms\x90\xa5flags\x90"

所以看起来一切都到了 REDIS,但套接字 io 服务器由于未知原因没有收到事件。

我正在考虑两者使用的不同频道 socket.io#emittersocket.io#/#socket.io-sync#request#/#。但就我读过的所有文章而言,他们都没有使用或更改它们。

所以也许它是一个不匹配的包版本?但是下面所有这个版本都是我的同事使用的......(我问他们这个问题,还在寻找)

在 PHP 上,我将 composer 用于:

{
    "require": {
        "rase/socket.io-emitter": "^0.7.0",
        "predis/predis": "^1.0"
    }
}

在 Socket IO 服务器上,npm 使用:

{
  "dependencies": {
    "dotenv": "~1.2.0",
    "longjohn": "~0.2.9",
    "socket.io": "~1.3.7",
    "socket.io-redis": "^1.1",
  }
}

如果有人有想法,我将不胜感激;)

编辑: 我的同事使用 Vagrant,我试了一下,看看是否有什么不同,是的,socket.io 服务器订阅的频道有所不同。 是psubscribe" "socket.io#* 而不是socket.io#/#,但他们没有触及任何东西,而且(码头工人和流浪者)的来源都是一样的,有点疯狂吧?..

【问题讨论】:

    标签: php node.js docker redis socket.io


    【解决方案1】:

    好的,将问题和解决方案分开。这里的问题是我对socket IO和Redis的误解和经验不足。

    当客户端通过 Redis 发射时,我应该有一个新的连接。 事实上,并非如此,新连接只会来自连接到 IO 套接字的客户端。 我使用 DEBUG=* 查看服务器上发生的一切,确实是的,套接字 IO 从 REDIS 获取信息。我错了,缺乏经验,只关注频道名称。

    我希望它对 Socket IO 和 Redis 的新手有所帮助 :)

    【讨论】:

      猜你喜欢
      • 2018-02-16
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-04-26
      相关资源
      最近更新 更多