5
我正在玩龙卷风和mongodb,与异步驱动电机。 使用回调处理一切都很好。后来我发现使用motor.Op或tornado.gen.Task仅在一个函数执行请求的可能性:如何在其他函数中移动db请求(使用yield)?
所以这是工作:
class Contact_handler(Main_handler):
@web.asynchronous
@gen.coroutine
def get(self, other_id):
event = events.Event_send_contact_request(self.user_id)
result = yield motor.Op(db.users.update,
{'_id': ObjectId(other_id)},
{'$push': {'evts': event.data}}
)
self.finish("ok")
但我想提出这个数据库在另一个模块中请求自己的功能。问题是,我不明白这里的收益率是如何工作的(尽管我读了很多关于收益率的问题)。 所以这是我试过,但它不工作:
#------ file views.py -------------
class Contact_handler(Main_handler):
def get(self, other_id):
event = events.Event_send_contact_request(self.user_id)
result = model.push_event_to_user(other_id, event)
self.finish("ok")
而在另一个函数调用:
#------ file model.py -------------
@gen.coroutine
def push_event_to_user(user_id, event):
## Ajout de la demande dans les events du demandé:
yield motor.Op(db.users.update,
{'_id': ObjectId(user_id)},
{'$push': {'evts': event}}
)
如果我调查与PDB:
(Pdb) l
157 event = events.Event_send_contact_request(self.user_id)
158 result = model.push_event_to_user(other_id, event)
159
160 import pdb; pdb.set_trace()
161
162 -> self.finish("ok")
163
(Pdb) result
<tornado.concurrent.TracebackFuture object at 0xa334b8c>
(Pdb) result.result()
*** Exception: DummyFuture does not support blocking for results
任何帮助表示赞赏, 谢谢。