2

我正在尝试在节点 js 和 python 3应用程序之间编写 IPC 的“hello world”。目前,当新消息到达 Python 应用程序时,我遇到了解析错误。代码是:

Python:

from ipcqueue import posixmq
from time import sleep

q1 = posixmq.Queue('/fila1')

while True:

    while q1.qsize() > 0:
        print('p1: Recebi na minha fila: ' + str(q1.get()))

    sleep(0.5)

节点:

const PosixMQ = require('posix-mq')

var mq = new PosixMQ();
mq.open({
    name: '/fila1',
    create: true,
    mode: '0777',
    maxmsgs: 10,
    msgsize: 11
});
mq.push("hello world")
mq.close();

当第二个应用程序发送消息时,python 应用程序失败并显示:

文件“../test-fila1.py”,第 9 行,在

print('p1: Recebi na minha fila: ' + str(q1.get()))   File "/usr/lib/python3.7/site-packages/ipcqueue/posixmq.py", line 174, in

得到

return self._serializer.loads(data)   File "/usr/lib/python3.7/site-packages/ipcqueue/serializers.py", line 14,

在负载

return pickle.loads(data) KeyError: 101

[2]- 退出 1 python3 ../test-fila1.py [3]+ 完成节点 index.js

编辑
所以,我决定将问题从“KeyError:101 在节点和 python 应用程序之间加载 ipc 消息时”更改为“如何使用 posix 消息队列在节点和 python 之间进行 IPC?” 因为我刚刚注意到我发布的示例代码每次运行时都会产生不同的错误。现在发生的错误是(但是,没有更改代码):

回溯(最后一次调用):文件“snippets/test-fila1.py”,
第 9 行,在
print('p1: Recebi na minha fila: ' + str(q1.get())) 文件“/usr/lib /python3.7/site-packages/ipcqueue/posixmq.py”,第 174 行,在
获取
返回 self._serializer.loads(data) 文件“/usr/lib/python3.7/site-packages/ipcqueue/serializers.py ",第 14 行,
在负载中
返回 pickle.loads(data)
_pickle.UnpicklingError: unpickling stack underflow

4

1 回答 1

7

如果你__init__Queue

class Queue(object):
    """
    POSIX message queue.
    """

    def __init__(self, name, maxsize=10, maxmsgsize=1024, serializer=PickleSerializer):

如您所见,默认serializer值为PickleSerializer,这意味着它假定队列中的数据是腌制的,而您从nodejs. 修复很简单,使用RawSerializer

from ipcqueue import posixmq
from time import sleep
from ipcqueue.serializers import RawSerializer
q1 = posixmq.Queue('/fila1', serializer=RawSerializer)

while True:

    while q1.qsize() > 0:
        print('p1: Recebi na minha fila: ' + str(q1.get()))

    sleep(0.5)

工作正常

于 2019-08-04T14:59:08.777 回答