gpt4 book ai didi

node.js - 是否可以看到与 socket.io 捆绑在一起的 redis 模块内部

转载 作者:可可西里 更新时间:2023-11-01 11:22:37 24 4
gpt4 key购买 nike

因为我们可以将 socket.io 配置为使用 redis 来实现它的内部工作方式,如下所示:

var RedisStore = require('socket.io/lib/stores/redis')
, redis = require('socket.io/node_modules/redis')
, pub = redis.createClient()
, sub = redis.createClient()
, client = redis.createClient();

io.set('store', new RedisStore({
redisPub : pub
, redisSub : sub
, redisClient : client
}));

如何查看此 RedisStore 的内部以查看 socket.io 正在插入和删除的数据。我将 socket.io 配置设置为使用从 node-redis 安装的 redis 实例,如下所示:

redis  = require('redis')

但我没有看到任何 socket.io 事件在进行,我想知道 socket.io 是否真的在使用 redis。我确实看到我的 cookie 存储在 redis 中,因为我将 express 和 connect 配置为使用 redis 作为 MemoryStore,但我没有看到任何与 socket.io 相关的内容。

最佳答案

对于本地 redis node.js 开发/调试,我这样做。

在后台启动 redis 服务器并在同一个 tty 中运行 cli 监视器:

redis-server &
redis-cli monitor -h host -p port

如果使用本地默认设置,您可以让-关闭。

您还可以运行一个 redis 从服务器,它回显所有主服务器命令,并将当前 redis 服务器的内存保存数据同步到默认为 ./dump.rdb 的文本文件中。该文件可以加载到 redis 中并使用文本编辑器查看。

 redis-cli --slave -h host -p port
vim ./dump.rdb

基本的 node.js Passport session cookie 看起来像这样:

sess:L2C4MPtAUmlO4zHGkXnq4icuÃ@U@Z{"cookie":{"originalMaxAg  null,"expiresÀhttpOnly":true,"path":"/"}passport L}

为了进一步帮助深入了解,您可能需要单步执行您的应用程序并在您的 Node 代码和 redis 驱动程序交互的区域放置断点。

您可以使用它来观察握手过程、查看不正确的数据交换、套接字问题等,方法是逐步执行您的函数,并观察控制流期间的状态变化。

此作业的 Node 应用程序是 Node 检查器。

它将允许您在类似的调试环境中查看您的应用程序运行情况到 Chrome 开发工具,您可以在其中设置断点以暂停、进入和退出功能,并及时向前移动直到下一个断点或异常触发暂停。

npm -g install node-inspector

当您在多个项目中使用它时,您可以使用“-g”全局开关安装它。

在终端窗口中不带任何选项运行程序会为我生成以下输出:

~/passaic-streaming git:weekend-refactor ❯❯❯
Node Inspector v0.7.0
Visit http://localhost:8080/debug?port=5858 to start debugging.

您可以使用 config 或 ENV 变量配置 HOST、PORT、DEBUG-PORT(DEBUG_PORT,端口5858,作为参数传递设置套接字连接在运行的 Node 进程和运行网络应用程序的浏览器之间。

现在,可以通过三种方式在 Debug模式下运行 node.js 代码。在第一次运行 node-inspector 之后执行此操作:

node --debug-brk app.js

node --debug app.js

node app.js // then send a SIGUSR1 to the node process:

// pgrep node
// kill -s USR1 PID

使用第一个命令“--debug-brk”,直到一切正常,因为它告诉您的代码在模块的第一行停止。

    browser http://localhost:8080/debug?port=5858

根据您的应用大小,加载可能需要一些时间。但是一旦到达那里,您将拥有一个用于逐步执行代码的源选项卡和一个控制台选项卡。

'--debug' 可以在 Express 应用程序上正常工作,您可能只需要点击一个端点或进行一些事务或告诉它手动在断点处暂停。

一些 Node 脚本太快而无法被 Node 检查器监听器捕获,并且在您在源代码中设置断点之前,可以方便地在第一行中断,因此命令。

您还可以在以下区域周围放置 'node debugger';行:

 // connect to Redis for sessionStore

node debugger; // node-inspector will pause here.

redisClient = redis.createClient(
options.PORT, options.HOST, options.REDIS_OPTIONS));

您可能需要使用 SIGUSR1 而不是在 Debug模式下启动应用程序的主要原因是您使用的是 node.js 集群 API。

如果您尝试监控使用集群并创建多个 Node 进程的应用程序,那么如果您尝试在 Node < 0.11.x 中进行调试,您将看到套接字的这个问题:

Failed to open socket on port 5858, waiting 1000 ms before retrying
Failed to open socket on port 5858, waiting 1000 ms before retrying

在不稳定的 Node 版本中,child_process.fork 命令监听调试器端口 5858+1、59、60 等,具体取决于您拥有的工作人员。

目前在 Node 0.10.x 中,如果您需要检查集群应用程序中工作程序的状态,您必须以非“--debug”模式启动 Node ,而不是向进程发送 kill USR1 信号。

要使用 redis 强制退出 Node ,请将 node_redis 驱动程序置于 Debug模式:

redis = require('redis');
redis.debug_mode = true; //turn on debug mode

另外,如果你像这样开始使用 connect-redis 中间件:

DEBUG=* node app.js

然后你会看到像这样的connect-redis输出:

connect:redis SETEX "sess:FVDBpNoFDFIOkynFDLcpM6St" ttl:604799 
{"cookie":{"originalMaxAge":604799991,"expires":"2014-03-08T22:38:32.620Z","httpOnly":true,"path":"/"},"passport":{"user":"52edfdfdf3da2rer0c06eb34"}} +50ms

最后,StrongOps/Strongloop 的团队内置了他们的部分命令行工具 node-inspector。

npm install -g strong-cli

slc debug app.js

它将启动 Node 检查器,将 Web 浏览器打开到适当的检查器,并且在最新的 Node 版本中——它理解集群。

关于node.js - 是否可以看到与 socket.io 捆绑在一起的 redis 模块内部,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14596296/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com