li88942 2015-10-21 15:11 采纳率: 0%
浏览 1823

有关python socket 多线程问题

我现在写的程序是模拟p2p DHT 就是peer1 知道peer2 和 peer3的port 依此类推 现在我写了一个程序 打开的每个xterm端口是一个peer 窗口里可以显示ping所返回的信息
代码如下
我测试了好久 有的显示返回信息 有的显示接收信息 有的豆显示 有的根本不显示
刚学编程半年 python很多东西不了解 socket 和多线程完全是先学先用的 所以请各位看一下
到底问题出在哪里

以下是代码

import sys
import time
import socket
import threading

class peer_server(threading.Thread):
def init(self):
threading.Thread.__init__(self)
self.ID = None
self.port = None
def run(self):
print(self.port)
server_port = self.port
serverSocket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
serverSocket.bind(('', server_port))
while 1:
message, clientAddress = serverSocket.recvfrom(2048)
sendMessage = 'A ping response message was received from Peer {:}'.format(self.ID)
serverSocket.sendto(sendMessage.encode('ascii') , clientAddress)
print('server {:}'.format(self.ID))
print(message.decode('ascii'))
print(time.time())

class peer_client(threading.Thread):
def init(self):
threading.Thread.__init__(self)
self.ID = None
self.port1 = None
self.port2 = None

def run(self):
    while 1:
        server_port = self.port1
        clientSocket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
        sendMessage = 'A ping request message was received from Peer {:}'.format(self.ID)
        clientSocket.sendto(sendMessage.encode('ascii'),('', server_port))
        receiveMessage, serverAddress = clientSocket.recvfrom(2048)
        print('client {:}'.format(self.ID))
        print(receiveMessage.decode('ascii'))
        print(time.time())
        clientSocket.close()
        server_port = self.port2
        clientSocket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
        clientSocket.sendto(sendMessage.encode('ascii'),('', server_port))
        receiveMessage, serverAddress = clientSocket.recvfrom(2048)
        print('client {:}'.format(self.ID))
        print(receiveMessage.decode('ascii'))
        print(time.time())
        clientSocket.close()
        time.sleep(5)

class peer(threading.Thread):
ID = None
port = None
port1 = None
port2 = None
def init(self, ID, fID, sID):
self.ID = ID
self.port = 50000 + ID
self.port1 = 50000 + fID
self.port2 = 50000 + sID
def start_server(self):
server = peer_server()
server.ID = self.ID
server.port = self.port
server.start()
def ping(self):
client = peer_client()
client.ID = self.ID
client.port1 = self.port1
client.port2 = self.port2
client.start()

p0 = peer(int(sys.argv[1]), int(sys.argv[2]), int(sys.argv[3]))
p0.start_server()
p0.ping()

  • 写回答

1条回答 默认 最新

  • li88942 2015-10-21 15:13
    关注

    xterm -hold -title "Peer 1" -e "python3 cdht.py 1 3 4" &
    xterm -hold -title "Peer 3" -e "python3 cdht.py 3 4 5" &
    xterm -hold -title "Peer 4" -e "python3 cdht.py 4 5 8" &
    xterm -hold -title "Peer 5" -e "python3 cdht.py 5 8 10" &
    xterm -hold -title "Peer 8" -e "python3 cdht.py 8 10 12" &
    xterm -hold -title "Peer 10" -e "python3 cdht.py 10 12 15" &
    xterm -hold -title "Peer 12" -e "python3 cdht.py 12 15 1" &
    xterm -hold -title "Peer 15" -e "python3 cdht.py 15 1 3" &

    测试的所需要的代码
    在terminal输入

    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog