【发布时间】: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#emitter、socket.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