我有一个由REST API提供的服务,Python库使用python-requests封装它。扭曲的服务器 - 客户端互连XML-RPC和REST服务
我有一个由第三方(不是Python)设计的'哑'用户界面连接到本地XML-RPC。
现在我必须连接两端,并将XML-RPC调用转发到REST API并返回结果。它大多是异步的,并不依赖于实时返回给用户的结果。大多数XML-RPC调用应该立即返回,排队任务,其他一些调用将在稍后查询结果。数据存储在sqlite数据库中直到需要。
所以,我决定使用twisted.web.xmlrpc这个中间层,并使用基于请求的远程调用lib,它工作正常。我想我偶尔阻止扭曲的主循环几秒钟,但这不是什么大不了的事。
问题是我还必须从这个中间层上传一些大文件上传到提供REST API的HTTP服务器。我无法使用基于lib的请求进行上传,因为它会阻止双绞线循环,直到上传完成。
我宁可不使用多线程,我真的不想重写基于python的lib作为一个扭曲的客户端。有什么办法可以将请求整合到twisted的主循环中,或者其他合理的解决方案吗?
“如何修改我的代码而不更改它?”这是一个艰难的。大多数修补程序至少涉及一些更改。 –
没有人喜欢smartass ... –
对不起,打扰你了。我会尽量在将来避开你的问题。 –