- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用来自许多 QThread 的 xmlrpc 客户端。为了确保只有一个线程正在使用 xmlrpc 客户端,我使用 QMutex 创建了锁。我的代码:
import sys
import xmlrpclib
import threading
import time
from SimpleXMLRPCServer import SimpleXMLRPCServer
from PyQt4 import QtCore, QtGui
class MM(object):
def __init__(self):
self.lock = QtCore.QMutex()
self.xmlrpc_client = xmlrpclib.ServerProxy('http://localhost:9092')
def __getattr__(self, name):
self.lock.lock()
sys.stderr.write('locked, for %s\n' % name)
print threading.current_thread()
result = self.xmlrpc_client.__getattr__(name)
sys.stderr.write('unlocked by %s\n' % name)
self.lock.unlock()
return result
class Server(QtCore.QThread):
def __init__(self):
QtCore.QThread.__init__(self)
self.server = None
def run(self):
self.server = SimpleXMLRPCServer(("localhost", 9092), logRequests = False)
def one():
return 1
self.server.register_function(one, 'one')
self.server.serve_forever()
print "SERVER DONE"
class Ask(QtCore.QThread):
def __init__(self, mmInst):
QtCore.QThread.__init__(self)
self.mm = mmInst
self._stopping = False
def run(self):
while not self._stopping:
time.sleep(0.5)
print self.mm.one()
def stop(self):
self._stopping = True
self.wait()
def start_gui():
app = QtGui.QApplication(sys.argv)
server = Server()
server.start()
time.sleep(1)
mm = MM()
print mm.one()
a1 = Ask(mm)
a1.start()
a2 = Ask(mm)
a2.start()
try:
app.exec_()
except KeyboardInterrupt:
server.server.shutdown()
if __name__ == "__main__":
start_gui()
但是它不起作用,我不知道为什么。这是输出:
locked, for one
<_MainThread(MainThread, started 1648)>
unlocked by one
1
locked, for one
<_DummyThread(Dummy-1, started daemon 356)>
unlocked by one
locked, for one
<_DummyThread(Dummy-2, started daemon 1480)>
unlocked by one
Traceback (most recent call last):
File "H:\poker\repos\TestSuite\test.py", line 46, in run
print self.mm.one()
File "C:\Python27\lib\xmlrpclib.py", line 1224, in __call__
return self.__send(self.__name, args)
File "C:\Python27\lib\xmlrpclib.py", line 1575, in __request
verbose=self.__verbose
File "C:\Python27\lib\xmlrpclib.py", line 1264, in request
return self.single_request(host, handler, request_body, verbose)
File "C:\Python27\lib\xmlrpclib.py", line 1289, in single_request
self.send_request(h, handler, request_body)
File "C:\Python27\lib\xmlrpclib.py", line 1391, in send_request
connection.putrequest("POST", handler, skip_accept_encoding=True)
File "C:\Python27\lib\httplib.py", line 853, in putrequest
raise CannotSendRequest()
httplib.CannotSendRequest
Traceback (most recent call last):
File "H:\poker\repos\TestSuite\test.py", line 46, in run
print self.mm.one()
File "C:\Python27\lib\xmlrpclib.py", line 1224, in __call__
return self.__send(self.__name, args)
File "C:\Python27\lib\xmlrpclib.py", line 1575, in __request
verbose=self.__verbose
File "C:\Python27\lib\xmlrpclib.py", line 1264, in request
return self.single_request(host, handler, request_body, verbose)
File "C:\Python27\lib\xmlrpclib.py", line 1294, in single_request
response = h.getresponse(buffering=True)
File "C:\Python27\lib\httplib.py", line 1015, in getresponse
raise ResponseNotReady()
httplib.ResponseNotReady
当仅使用一个线程时工作正常:
$ diff -u test.py.back test.py
--- test.py.back 2012-03-14 01:34:37.666425000 +0100
+++ test.py 2012-03-14 01:33:01.423265000 +0100
@@ -63,8 +63,8 @@
a1 = Ask(mm)
a1.start()
- a2 = Ask(mm)
- a2.start()
+ #a2 = Ask(mm)
+ #a2.start()
try:
app.exec_()
$ python test.py
locked, for one
<_MainThread(MainThread, started -1219930432)>
unlocked by one
1
locked, for one
<_DummyThread(Dummy-1, started daemon -1287918736)>
unlocked by one
1
locked, for one
<_DummyThread(Dummy-1, started daemon -1287918736)>
unlocked by one
1
locked, for one
<_DummyThread(Dummy-1, started daemon -1287918736)>
unlocked by one
1
当使用两个不同的 MM 实例时也可以正常工作:
$ diff -u test.py.back test.py
--- test.py.back 2012-03-14 01:34:37.666425000 +0100
+++ test.py 2012-03-14 01:38:47.352862000 +0100
@@ -57,13 +57,13 @@
time.sleep(1)
- mm = MM()
- print mm.one()
+ #mm = MM()
+ #print mm.one()
- a1 = Ask(mm)
+ a1 = Ask(MM())
a1.start()
- a2 = Ask(mm)
+ a2 = Ask(MM())
a2.start()
try:
adam@sabayon /media/Nowy/poker/repos/TestSuite $ python test.py
locked, for one
locked, for one
<_DummyThread(Dummy-1, started daemon -1288275088)><_DummyThread(Dummy-2, started daemon -1298138256)>
unlocked by one
unlocked by one
11
locked, for one
<_DummyThread(Dummy-2, started daemon -1298138256)>
unlocked by one
locked, for one
<_DummyThread(Dummy-1, started daemon -1288275088)>
unlocked by one
1
1
locked, for one
<_DummyThread(Dummy-1, started daemon -1288275088)>
unlocked by one
locked, for one
1<_DummyThread(Dummy-2, started daemon -1298138256)>
unlocked by one
1
最佳答案
我在代码中发现了一些问题,但主要是我立即遇到的问题是您在服务器准备就绪之前启动了客户端。当我首先实例化服务器,然后实例化客户端时,我不再收到连接错误。
我还删除了旋转的 while 循环,而只是启动了 pyqt 事件循环。另外,您并没有真正将 MM 实例传递给 Ask 类(这对于本示例来说并不重要,因为您使用的是相同的实例)。
无论如何,这是我的版本,似乎可以正常工作:
import sys
import xmlrpclib
import threading
import time
from SimpleXMLRPCServer import SimpleXMLRPCServer
from PyQt4 import QtCore, QtGui
class MM(object):
def __init__(self):
self.lock = QtCore.QMutex()
self.xmlrpc_client = xmlrpclib.ServerProxy('http://localhost:9092')
def __getattr__(self, name):
self.lock.lock()
sys.stderr.write('locked, for %s\n' % name)
print threading.current_thread()
result = self.xmlrpc_client.__getattr__(name)
sys.stderr.write('unlocked by %s\n' % name)
self.lock.unlock()
return result
class Server(QtCore.QThread):
def __init__(self):
QtCore.QThread.__init__(self)
self.server = None
def run(self):
self.server = SimpleXMLRPCServer(("localhost", 9092), logRequests = False)
def one():
return 1
self.server.register_function(one, 'one')
self.server.serve_forever()
print "SERVER DONE"
class Ask(QtCore.QThread):
def __init__(self, mmInst):
QtCore.QThread.__init__(self)
self.mm = mmInst
self._stopping = False
def run(self):
while not self._stopping:
time.sleep(0.5)
print self.mm.one()
def stop(self):
self._stopping = True
self.wait()
def start_gui():
app = QtGui.QApplication(sys.argv)
server = Server()
server.start()
time.sleep(.25)
mm = MM()
print mm.one()
a1 = Ask(mm)
a1.start()
a2 = Ask(mm)
a2.start()
try:
app.exec_()
except KeyboardInterrupt:
server.server.shutdown()
if __name__ == "__main__":
start_gui()
经过更多研究后,我意识到这是 python 2.7 和 xmlrpc 中的一个错误,它们改变了创建连接的方式。 http://bugs.python.org/issue6907
奇怪的是,这段代码在 OSX 上的 python 2.6/2.7 上或在 linux 下的 python 2.6 上不会崩溃。但对于我来说,在 linux 下使用 python 2.7 确实会崩溃。
当我将锁定机制移到 MM 实例之外时,它似乎开始在 Linux 上的 2.7 下工作:
class MM(object):
def __init__(self):
self.xmlrpc_client = xmlrpclib.ServerProxy('http://localhost:9093')
def __getattr__(self, name):
return self.xmlrpc_client.__getattr__(name)
class Ask(QtCore.QThread):
def __init__(self, mmInst, lock):
QtCore.QThread.__init__(self)
self.mm = mmInst
self.lock = lock
def run(self):
while not self._stopping:
time.sleep(0.5)
self.lock.lock()
print self.mm.one()
self.lock.unlock()
def start_gui():
app = QtGui.QApplication(sys.argv)
...
lock = QtCore.QMutex()
a1 = Ask(mm, lock)
a1.start()
a2 = Ask(mm, lock)
a2.start()
关于python - QThreads 和 xmlrpc 客户端,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9691938/
服务器代码(基于 Python 库引用): from xmlrpc.server import SimpleXMLRPCServer from xmlrpc.server import SimpleX
有什么方法可以同时从一个 xmlrpc 客户端向不同的 xmlrpc 服务器发出多个调用。 我的服务器代码如下所示:(我将让这段代码在两台机器上运行,server1 和 server2) class
我在我的 Apache 服务器上安装了 xmlrpc-epi,我需要使用它来连接到 XMLRPC 服务器。我应该做什么 - 除了 xmlprc-api 之外,我还需要在我的服务器上下载和/或安装什么吗
我正在构建一个使用wordpress-java库的android应用,但出现了"Failed to resolve: redstone.xmlrpc:xmlrpc:1.1.1"错误。 Build.Gr
实际上需要传递一个参数,该参数是一个xml作为带有xmlrpc Node 模块的对象github.com/baalexander/node-xmlrpc; 客户端调用是: client.methodC
我有一个运行 Python 的 XML RPC 服务器。 它作为 SimpleXMLRPCServer 类的实例实现。 from SimpleXMLRPCServer import SimpleXML
我不会从表格中读取行来将主题放在列表中 php脚本 $url_obj='http://'.$host.':8069/xmlrpc/object'; $sock=new xmlrpc_client($u
如何将脚本执行错误传递给 XMLRPC 响应,以免出现故障异常? 也许我没有正确设置: 在 XMLRPC 服务器中,我添加了 Zend_XmlRpc_Server_Fault::attachFault
有关如何使用 XMLRPC 实现基本身份验证的任何线索或示例org.apache.xmlrpc.webserver.WebServer? 我正在使用 Java API apache-xmlrpc-3.
我有一个使用 GHC 运行的 Haskell RPCXML (HaXR) 服务器进程,它需要执行它传递的任何函数。这些函数都将在运行时定义,因此编译后的服务器不会知道它们。 有没有办法在运行时加载函数
我使用 xmlrpc 服务器运行简单示例,然后按键盘上的 Ctrl-C :)。 from SimpleXMLRPCServer import SimpleXMLRPCServerfrom time i
我正在使用 HTML5 + Phonegap 进行移动应用程序开发。目前正在使用 XMLRPC 开发移动应用程序,并且运行良好。 (Android 和 iOS) 我需要在浏览器中运行与网站 相同的应用
我想创建非阻塞扭曲的 xmlrpc,但我不知道。我想在 xmlrpc 中调用方法,并且每次都从任何客户端执行我的方法,无需等待。这是我的代码: from pymongo import MongoCli
是否有可能允许 Python simplexmlrpc 服务器的 xmlrpc 扩展(数据类型 long int)? 客户端使用 Apache xmlrpc,allows 8 byte integer
我正在寻找一种方法来防止多个主机同时向 Python XMLRPC 监听器发出命令。监听器负责运行脚本以在该系统上执行任务,如果多个用户试图同时发出这些命令,这些任务将会失败。有没有一种方法可以阻止所
本文整理了Java中org.apache.xmlrpc.XmlRpcConfig类的一些代码示例,展示了XmlRpcConfig类的具体用法。这些代码示例主要来源于Github/Stackoverfl
对你们来说很简单的问题。 我可以通过 xmlrpc 删除未附加的媒体吗?如果是这样,请指导我了解什么功能可以做到这一点。谢谢 最佳答案 绝对可以,你用wp.deletePost以 post_id 作为
我的任务是创建一个 API,用于从 Flash 应用程序和旧版 CMS(非 PHP)检索内容并将其添加到 Wordpress。我的计划是利用现有的默认 xmlrpc 端点,并通过创建一个 Hook 到
所以我有一个 XMLRPC 服务器,它有一个名为 start_apps 的命令 通常从Python我会像这样运行它 import xmlrpclib app=xmlrpclib.ServerProxy
所以我有一个 XMLRPC 服务器,它有一个名为 start_apps 的命令 通常从Python我会像这样运行它 import xmlrpclib app=xmlrpclib.ServerProxy
我是一名优秀的程序员,十分优秀!