- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
因为我们可以将 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/
基于 socket.io 的官方网站 http://socket.io/#how-to-use , 我找不到任何术语。socket.emit 、 socket.on 和 socket.send 之间有
我正在使用 lua-socket 3.0rc1.3(Ubuntu Trusty 附带)和 lua 5.1。我正在尝试监听 unix 域套接字,我能找到的唯一示例代码是 this -- send std
这两者有什么区别? 我注意到如果我在一个工作程序中从 socket.emit 更改为 socket.send ,服务器无法接收到消息,虽然我不明白为什么。 我还注意到,在我的程序中,如果我从 sock
使用套接字在两台服务器之间发送数据是个好主意,还是应该使用 MQ 之类的东西来移动数据。 我的问题:套接字是否可靠,如果我只需要一次/有保证的数据传输? 还有其他解决方案吗? 谢谢。 最佳答案 套接字
引自 this socket tutorial : Sockets come in two primary flavors. An active socket is connected to a
我已经安装了在端口81上运行的流服务器“Lighttpd”(light-tpd)。 我有一个C程序,它使用套接字api创建的服务器套接字在端口80上监听http请求。 我希望从客户端收到端口80上的请
这是我正在尝试做的事情: 当有新消息可用时,服务器会将消息发送给已连接的客户端。另一方面,客户端在连接时尝试使用send()向服务器发送消息,然后使用recv()接收消息,此后,客户端调用close(
如何将消息发送到动态 session 室,以及当服务器收到该消息时,如何将该消息发送到其他成员所在的同一个 session 室? table_id是房间,它将动态设置。 客户: var table_i
这是我尝试但不起作用的方法。我可以将传入的消息从WebSocket连接转发到NetSocket,但是只有NetSocket收到的第一个消息才到达WebSocket后面的客户端。 const WebSo
我正在实现使用boost将xml发送到客户端的服务器。我面临的问题是缓冲区不会立即发送并累积到一个点,然后发送整个内容。这在我的客户端造成了一个问题,当它解析xml时,它可能具有不完整的xml标记(不
尝试使用Nginx代理Gunicorn套接字。 /etc/systemd/system/gunicorn.service文件 [Unit] Description=gunicorn daemon Af
我正在使用Lua套接字和TCP制作像聊天客户端和服务器这样的IRC。我要弄清楚的主要事情是如何使客户端和服务器监听消息并同时发送它们。由于在服务器上执行socket:accept()时,它将暂停程序,
我看了一下ZMQ PUSH/PULL套接字,尽管我非常喜欢简单性(特别是与我现在正在通过UDP套接字在系统中实现的自定义碎片/ack相比),但我还是希望有自定义负载平衡功能,而不是幼稚的回合-robi
我正在编写一个应用程序,其中有多个 socket.io 自定义事件,并且所有工作正常,除了这个: socket.on("incomingImg", function(data) {
在我的应用程序中,我向服务器发送了两条小消息(类似 memcached 的服务)。在类似 Python 的伪代码中,这看起来像: sock.send("add some-key 0") ignored
很抱歉再次发布此问题,但大多数相关帖子都没有回答我的问题。我在使用 socket.io 的多个连接时遇到问题我没有使用“socket.socket.connect”方法,但我从第一次连接中得到了反馈。
我尝试使用 socket.io 客户端连接到非 socket.io websocket 服务器。但我做不到。我正在尝试像这样连接到套接字服务器: var socket = io.connect('ws
我遇到了一个奇怪的问题。在我非常基本的服务器中,我有: server.listen(8001); io.listen(server); var sockets = io.sockets; 不幸的是,套
我正在使用带套接字 io 的sailsjs。帆的版本是 0.10.5。我有以下套接字客户端进行测试: var socketIOClient = require('socket.io-client');
这个问题在这里已经有了答案: What is the fundamental difference between WebSockets and pure TCP? (4 个答案) 关闭 4 年前。
我是一名优秀的程序员,十分优秀!