在学习廖雪峰的官方网站:分布式进程时遇到如下错误:
Put task 919
Traceback (most recent call last):
File "e:\WorkSpace\Code\Python\task_manager.py", line 42, in <module>
task.put(n)
^^^^^^^^
AttributeError: 'AutoProxy[get_task_queue]' object has no attribute 'put'
经过排查发现主要原因是
解决方法:
将
def task_queue():
return task_queue
def result_queue():
return result_queue
if __name__ == '__main__':
# Queue注册到网络上
QueueManager.register('get_task_queue', callable = task_queue)
QueueManager.register('get_result_queue', callable = task_queue)
修改为:
def g_task_queue(): #函数名称和变量名称区别开
return task_queue
def g_result_queue():#函数名称和变量名称区别开
return result_queue
if __name__ == '__main__':
# Queue注册到网络上
QueueManager.register('get_task_queue', callable = g_task_queue) # 新的函数名
QueueManager.register('get_result_queue', callable = g_task_queue) # 新的函数名称
但是没理解为什么会出现这种原因?使用type()查看两者的类型都是一样的
修改名称前:
修改名称后: