- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
编辑:原来是一个莳萝错误,请参阅答案。
编辑:寻找我的错误排查进度的底部,原来是由numpy.min取代了内置的min函数引起的
我正在使用Pyro(版本4.43,Python 3.5.1,Windows 10)并尝试建立一个简单的集群,服务器进程在其中等待工作程序,工作程序请求工作并发回结果。服务器收到结果后,将对其进行进一步处理。
目前,我只是想让它在一台计算机上工作(使用localhost并从同一台计算机生成工作进程)。
到目前为止,我已经能够使服务器进程运行,并且工作进程能够连接到服务器以请求数据,处理该数据,但是当工作进程尝试将结果发送回服务器时,工作进程会出错。
我遇到一个奇怪的错误消息:
File "worker.py", line 90, in <module>
main()
File "worker.py", line 87, in main
worker.send_result()
File "worker.py", line 49, in send_result
self.server.recieve(result)
File "C:\Anaconda3\lib\site-packages\Pyro4\core.py", line 171, in __call__
return self.__send(self.__name, args, kwargs)
File "C:\Anaconda3\lib\site-packages\Pyro4\core.py", line 418, in _pyroInvoke
self.__pyroCheckSequence(msg.seq)
File "C:\Anaconda3\lib\site-packages\Pyro4\core.py", line 448, in __pyroCheckSequence
raise errors.ProtocolError(err)
Pyro4.errors.ProtocolError: invoke: reply sequence out of sync, got 0 expected 2
#simple_server.py
import Pyro4
import sys, dill
class SimpleServer:
def serve(self):
with open('served data.pkl', 'rb') as f:
data = dill.load(f) #actual data coming from production code
return data
def recieve(self, result):
print(result)
def main():
Pyro4.config.SERIALIZER = 'dill' #default serpent serializer doesn't work
dill.settings['recurse'] = True #dill won't work without this option
server = SimpleServer()
daemon = Pyro4.Daemon()
server_uri = daemon.register(server)
ns = Pyro4.locateNS()
ns.register("test", server_uri)
print('Server running.')
daemon.requestLoop()
if __name__ == '__main__':
main()
#simple_worker.py
import Pyro4
import sys, dill
import numpy as np
import scipy.optimize as opt
class SimpleWorker:
def __init__(self, server):
self.server = server
def recieve_data(self):
self.data = self.server.serve()
def send_result(self):
res = opt.basinhopping(lambda x: sum(x), np.arange(11), niter=2, minimizer_kwargs={'options':{'maxiter':2}})
#This below data structure is the same that I send in production
result = ('ABCD', 'filename.csv', res, 6)
self.server.recieve(result) #creates error in production code but not here
def main():
sys.excepthook = Pyro4.util.excepthook #gives a more meaningful stack trace
Pyro4.config.SERIALIZER = 'dill' #default serpent serializer doesn't work
dill.settings['recurse'] = True #dill won't work without this option
server = Pyro4.Proxy('PYRONAME:test') #connects to pinest server
worker = SimpleWorker(server)
worker.recieve_data()
worker.send_result()
if __name__ == '__main__':
main()
#run_simple_server.bat
set PYRO_SERIALIZERS_ACCEPTED=serpent,json,marshal,pickle,dill
start cmd /C python -m Pyro4.naming
python simple_server.py
pause
#run_simple_worker.bat
python simple_worker.py
pause
Pyro4.current_context.seq
,它将返回0。如果尝试
Pyro4.current_context.seq = 2
,则不会影响该错误。
min(60000, size - msglen)
。当执行该命令时,它使用的是numpy.min而不是内置的min,并且会出错,因为numpy.min的第二个参数应该是轴号。这是令人惊讶的,因为我只在代码中导入了
numpy as np
,而从不导入
from numpy import *
或直接导入min函数。
import builtins
然后
min = builtins.min
,错误仍然存在。如果运行
inspect.getfile(builtins.min)
,它将指向Numpy文件。
min([60000, size - msglen])
的行来完全避免该问题,该行适用于numpy和内置的min,但是min分配仍然保留在我的服务器代码中,并且在那里也弄乱了功能。
#Store builtin functions as they later get replaced for some unknown reason
b = [t for t in ().__class__.__base__.__subclasses__() if t.__name__ == 'Sized'][0].__len__.__globals__['__builtins__']
self.real_builtins = copy.copy(b) #copy so that dict doesn't get updated
def fix_builtins(self):
global builtins
import builtins
__builtins__ = self.real_builtins
#These are all of [i for i in dir(builtins) if i in dir(numpy)]
builtins.abs = __builtins__['abs']
builtins.all = __builtins__['all']
builtins.any = __builtins__['any']
builtins.bool = __builtins__['bool']
builtins.complex = __builtins__['complex']
builtins.float = __builtins__['float']
builtins.int = __builtins__['int']
builtins.max = __builtins__['max']
builtins.min = __builtins__['min']
builtins.object = __builtins__['object']
builtins.round = __builtins__['round']
builtins.str = __builtins__['str']
builtins.sum = __builtins__['sum']
最佳答案
这是一个莳萝错误,它是由腌制经过lambdified的Sympy表达式引起的。下面的代码重现该错误:
from sympy import symbols, lambdify
import dill, inspect
def check_if_builtin(func):
try:
file = inspect.getsourcefile(func) #will throw TypeError for builtin
return file
except TypeError:
return True
dill.settings['recurse'] = True #without this option, throws PicklingError
a, b, c = symbols("a b c")
expr = a + b + c
lambda_expr = lambdify([a, b, c], expr)
print(check_if_builtin(min))
dill.dump(lambda_expr, open('test.p', 'wb'))
print(check_if_builtin(min))
True
C:\Anaconda3\lib\site-packages\numpy\core\fromnumeric.py
关于python - Python:Numpy.min替换了内置函数:导致Pyro4错误:回复序列不同步,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36961157/
我有多个 InOut 模式的顺序队列,每个队列通向一个 Camel 处理器。如果处理器花费太多时间进行处理,我希望请求-答复检测到超时并发送 ExchangeTimedOutException。Cam
我是一名学生,试图了解更多关于 C# 中的 ARP 和套接字的信息 为此,我尝试使用原始 Socket 发送 ARP 请求和回复。在 C# 中。 我已经在一个字节数组中手动重建了一个 ARP 回复
我正在使用 Amazon Web Services 数据库 dynamodb。它返回一个 JSON,看起来像这样: {"Responses":{"friends":[{"to_username":"u
我有 servlet,它创建 html 文件,然后将其转换为 pdf 文件: private void ConvertHTMLtoPDF(String sConvertationProgramm, S
我正在为我的项目使用 Mailkit 库 (Imap)。 我可以轻松地通过 SmtpClient 发送新消息。 目前我正在研究如何回复特定邮件。是否可以向该回复邮件添加更多收件人? @jstedfas
这个问题已经有答案了: How to parse JSON in Java (36 个回答) 已关闭 7 年前。 请您告诉我如何解析 JSON 回复。我从 https://api.privatbank
我正在尝试从事 YouTube 视频评级工作。但我被困在这里了。这两个 YouTube 评级请求有什么区别? https://www.googleapis.com/youtube/v3/videos/
我搜索了该网站,令人惊讶的是没有找到任何适合我情况的答案。所以我发布了这个问题。 我正在使用 jQuery AJAX 来获取网页并将其动态添加到网站。但我的代码不起作用并抛出错误 ERROR Type
我正在编写一个 C 程序来搜索本地网络上的 smb 共享并安装它们。为了获取找到的 smb 服务器的主机名,我向服务器发送了 udp nbns 数据包。数据包正确,服务器回复。我正在使用wiresha
我正在尝试使用 Java 创建自己的 WebSocket 服务器。 当我的客户端连接时,我收到以下请求: (14): GET / HTTP/1.1 (18): Upgrade: WebSocket (
我正在使用 Nodejs、Express、MySQL、EJS。 用户能够创建帖子和评论/回复评论/回复对这些帖子的回复。 问题:我不知道如何以允许我在 EJS 中呈现它们的方式将数据分类为对象/数组。
我正在用 .NET c++ 编写程序。我正在本地网络上发送广播 ping。我的所有目标设备都能够响应 ping 广播,事实上我在 Wireshark 中跟踪了它们的所有响应。我的目标是检索所有响应站点
我有一个向 JMS MDB 发送请求的客户端。它可以很好地向 MDB 发送消息,但我一辈子都无法弄清楚如何让客户端接收 MDB 发回给它的响应。 编辑:客户端代码是同一实例上的 Web 服务,使用 @
我使用钩子(Hook)函数制作了一个模块。它可以工作,但是当我使用 ping google.com 时,我得到 0045 作为 icmp 类型。但我认为它应该是 0 用于回显回复。我使用了以下打印命令
我正在用 C 从头开始编写一个网络库。我已经实现了以太网协议(protocol),现在我想让 ARP 工作。发送请求/回复工作正常,但接收工作不正常。当我发送一个发送请求并等待它之后的回复时,re
我在替换字符串的一部分时遇到问题。现在这段代码。我的目标是针对包含此字典中的键的每个字符串。 mapping = { "St": "Street", "St.": "Stree
我有一个 WCF p2p 网状网络,它运行良好,适合单向对话。我正在研究是否可以调用一种方法来添加两个数字并返回和总和。 但是我在尝试连接时遇到错误: 契约(Contract)需要请求/回复,但绑定(
大家好,我正在尝试使用分块编码流式传输多媒体数据。因此,我首先尝试使用分块编码发送文本数据。 这是我的代码。我创建了一个服务器套接字,我在上面监听请求(端口 80),回复请求,然后我的程序终止。无论您
我的 Servlet 中有一些图像,我想将它们下载到我的 Android 应用中。 我正在对这个 URL 执行一个 GET 请求: public static final String URL ="h
文档:https://developers.google.com/apps-script/reference/gmail/gmail-message#replybody-options 当跟进一封电子
我是一名优秀的程序员,十分优秀!