如何在不同的VM上制作多线程套接字

时间:2019-12-14 02:37:06

标签: python sockets network-programming

我要实现多线程服务器从不同VM上的多个客户端接收连接。 3个VM在同一子网中。我想问一下如何通过在vms上配置网络来使其相互连接,以及如何在代码中更改ip和端口。这是服务器上的代码:

import socket
from threading import Thread
from SocketServer import ThreadingMixIn

TCP_IP = 'localhost'
TCP_PORT = 12345
BUFFER_SIZE = 1024

class ClientThread(Thread):

    def __init__(self,ip,port,sock):
        Thread.__init__(self)
        self.ip = ip
        self.port = port
        self.sock = sock
        print " New thread started for "+ip+":"+str(port)

    def run(self):
        filename='mytext.txt'
        f = open(filename,'rb')
        while True:
            l = f.read(BUFFER_SIZE)
            while (l):
                self.sock.send(l)
                l = f.read(BUFFER_SIZE)
            if not l:
                f.close()
                self.sock.close()
                break

tcpsock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcpsock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
tcpsock.bind((TCP_IP, TCP_PORT))
threads = []

while True:
    tcpsock.listen(5)
    print "Waiting for incoming connections..."
    (conn, (ip,port)) = tcpsock.accept()
    print 'Got connection from ', (ip,port)
    newthread = ClientThread(ip,port,conn)
    newthread.start()
    threads.append(newthread)

for t in threads:
    t.join()

Client1:

import socket

TCP_IP = 'localhost'
TCP_PORT = 12345
BUFFER_SIZE = 1024

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((TCP_IP, TCP_PORT))
with open('received_file', 'wb') as f:
    print 'file opened'
    while True:
        data = s.recv(BUFFER_SIZE)
        print('data=%s', (data))
        if not data:
            f.close()
            print 'file close()'
            break
        f.write(data)
s.close()
print('connection closed')

Client2:

 import socket

TCP_IP = 'localhost'
TCP_PORT = 12345
BUFFER_SIZE = 1024

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((TCP_IP, TCP_PORT))
with open('received_file', 'wb') as f:
    print 'file opened'
    while True:
        data = s.recv(BUFFER_SIZE)
        print('data=%s', (data))
        if not data:
            f.close()
            print 'file close()'
            break
        f.write(data)
s.close()
print('connection closed')

1 个答案:

答案 0 :(得分:0)

当您绑定到“ localhost” IP地址时,这意味着您的服务器开始在地址为127.0.0.1的“环回”内部虚拟网络接口上侦听,该接口可以从本地计算机访问,而不能从外部访问。

您的服务器不会侦听世界上任何物理接口,因此即使配置正确的客户端也无法从远程节点连接到服务器。

您可以将“ localhost”替换为“ 0.0.0.0”,这意味着“绑定到所有可用接口”。 这意味着您可以在不知道自己服务器IP地址的情况下启动服务器。 它将在VM中配置的所有物理和虚拟接口上等待传入连接。

TCP_IP = '0.0.0.0'
tcpsock.bind((TCP_IP, TCP_PORT))

但是客户端需要知道服务器的IP地址才能连接到它。

现在您的客户端尝试使用IP地址127.0.0.1连接到他们自己的VM

您需要为客户端提供服务器的真实IP地址,以便他们连接到服务器。

假设您的服务器地址为192.168.4.4

然后您的客户代码应如下所示:

TCP_IP = '192.168.4.4'
s.connect((TCP_IP, TCP_PORT))