我已经挖掘了一段时间,我已经有了很好的理解,没有什么能完全达到我想要做的事情:
我需要一个可以连接多个客户端的服务器。每隔一段时间,客户端就会向服务器查询一组要处理的新数字(本质上是分布式计算),然后服务器将其发送回查询的客户端。
我如何知道哪个客户端查询了服务器,以便我可以回复它?
我对 Python 还很陌生,select() 函数本身有点令人困惑。我能够接受新连接并获得输入,但服务器似乎不知道哪个客户端正在与它交谈(或者我的调试文本可能不正确,它确实知道??)。
无论如何,这是服务器的代码:
while running:
#select returns 3 subsets of the input containing sockets that have stuff to be read, empty buffer for writing, or an error
readers, writers, error = select.select(input, output, errors)
for s in readers:
if s == serversocket:
#readable server socket is ready for connection
connection, client_addr = s.accept()
print >> sys.stderr, 'new connection from', client_addr
connection.setblocking(0)
#clients.append([client_addr, performance])
input.append(connection)
output.append(connection)
else:
#readable socket, not ready for new connection
data = s.recv(1024)
print >> sys.stderr, "readable socket, not ready for new connection"
if data:
#the socket actually has data (put Compute process data into list)
print >> sys.stderr, "Data received"
substring = data[0:data.find("sss")];
print >> sys.stderr, 'received %s from %s' % (substring, client_addr)
if substring == "-get":
print >> sys.stderr, 'received -get command'
determinerange()
print >> sys.stderr, 'sending range of %d to %d', currentlow, currenthigh
temp = currentlow+"\0"
connection.send(currentlow)
temp = currenthigh+"\0"
connection.send(currenthigh)
elif substring == "-k":
print >> sys.stderr, 'received -k, stopping'
本质上,它接收某种命令,然后转身发送它需要的数据。如果您想知道,该服务器必须与我也在编写的 C 程序通信,该程序实际上进行计算。这就是为什么我要附加换行符“\0”字符。如果它从任何客户端接收到 -k,它需要停止每个客户端并退出。
注意:我只能使用标准的 python 库。我无法得到任何能让事情变得更容易的额外东西:)
提前感谢大家的帮助!