1

我正在尝试使用 JavaScript 对 Python RQ 的任务进行排队。为此,我只是监控了 RQ 对 Redis 的作用。特别是它存储了一个腌制列表,指示在哪里可以找到要运行的任务,包括输入参数等。这里我使用的是 RQ 主页上的示例。存储以下字符串(腌制列表)时:

'\x80\x02(X\x1c\x00\x00\x00my_module.count_words_at_urlq\x01NU\x0fhttp://nvie.comq\x02\x85q\x03}q\x04tq\x05.'

使用 JavaScript,它对文字\x80\x85. 它将它们替换为\xc2\x80and\xc2\x85我无法弄清楚为什么以及如何阻止这种行为。字符串的其余部分按预期汇入 Redis。额外的文字会阻碍 rqworker,更具体地说是 pickle,正常运行。

> encodeURI('\x80\x02(X\x1c\x00\x00\x00my_module.count_words_at_urlq\x01NU\x0fhttp://nvie.comq\x02\x85q\x03}q\x04tq\x05.')
'%C2%80%02(X%1C%00%00%00my_module.count_words_at_urlq%01NU%0Fhttp://nvie.comq%02%C2%85q%03%7Dq%04tq%05.'

> decodeURI('\x80\x02(X\x1c\x00\x00\x00my_module.count_words_at_urlq\x01NU\x0fhttp://nvie.comq\x02\x85q\x03}q\x04tq\x05.')
' \u0002(X\u001c\u0000\u0000\u0000my_module.count_words_at_urlq\u0001NU\u000fhttp://nvie.comq \u0002q\u0003}q\u0004tq\u0005.'

我正在使用节点和 node_redis。

4

1 回答 1

1

我自己发现的。Python 的 pickle 输出字符串实际上是二进制的,这是在 Python 中写入和读取文件的常用方法。Javascript 不喜欢这样并“修复”它。解决方案是 Javascript 的缓冲区。

> new Buffer('\x80\x85', 'binary')
<Buffer 80 85>

然而

> new Buffer('\x80\x85')
<Buffer c2 80 c2 85>

只需向 node_redis 提供缓冲区对象,序列化对象的“正确”表示将出现在 redis 中,并且 rqworker 按预期工作。请记住,“二进制”模式正在被弃用。

于 2015-04-02T12:04:53.150 回答