使用套接字TCP

时间:2015-12-06 18:24:28

标签: python sockets tcp concurrency concurrent-programming

我正在编写一个TCP并发(基于进程的并发)服务器,它接受一个下载命令。客户端应该从服务器下载文件,截至目前我的文件名已经过硬编码下载,以便测试我的下载算法。

我查找了一个示例download algorithm并使用了该代码中使用的while循环。

我认为我的问题是,其中一个while循环(或者两个都可能)被挂断并且不会结束。 我相信它是客户端,它可能正在等待更多的fileContent。

服务器

            file = open('download.txt','rb+')
            print "Opened File: " , file.name

            fileContent = file.read(1)
            clientsocket.send(fileContent)
            while (fileContent):
                print "iteration", fileContent
                clientsocket.send(fileContent)
                fileContent = file.read(1)                  
            file.close()

客户端

    print "Attempting download..."
    f = open('downloaded.txt' , 'wb+')      
    print "Opened File: " , f.name
    fileContent = s.recv(1)
    while (fileContent):
        print "iteration", fileContent
        f.write(fileContent)
        fileContent = s.recv(1)
    print "Download Complete"
    f.close()

我使用

之类的代码完成了没有while循环的文件传输
 f.open(file)
 fContent = f.read(1024)
 client.send(fContent)
 f.close

 f.open(file)
 fContent = server.recv(1024)
 f.write(fContent)
 f.close 

但我知道如果文件大于缓冲区大小会导致问题。

这是一个并发服务器,它使用单个进程来处理每个连接。 (我不相信这会影响我当前的问题,但我是并发的新手,并认为我会提到它。)

有谁知道为什么我的while循环没有结束?或者有人知道我可能做错的其他事吗?提前谢谢!

编辑:

我的输出:

cli

Attempting download...
Opened File:  downloaded.txt
iteration t
iteration h
iteration i
iteration s
iteration
iteration i
iteration s
iteration
iteration a
iteration
iteration f
iteration i
iteration l
iteration e
iteration

SERV

Recived  dl from:  ('127.0.0.1', 38161)  |  2015-12-06 13:07:12.835998
Opened File:  download.txt
iteration t
iteration h
iteration i
iteration s
iteration
iteration i
iteration s
iteration
iteration a
iteration
iteration f
iteration i
iteration l
iteration e
iteration

客户端卡住了,我必须把它拉出来。服务器将继续接受连接。我刚刚意识到我可以在服务器的while循环之后添加一个简单的print语句来检查服务器的while循环是否完成。

第二次编辑:

服务器没有挂断(它在循环后成功显示消息)。这让我相信客户端正在调用recv()并等待更多的fileContent。

第3次编辑:

为了测试目的,读/写缓冲区仅为1。

1 个答案:

答案 0 :(得分:1)

逐字节发送文件可能会非常慢。最好使用shutil.copyfileobj,为您处理转移:

def send_file(socket, filename):
    with open('download.txt','rb') as inp:
        print "Opened File: " , file.name
        out = socket.makefile('wb')
        shutil.copyfileobj(inp, out)

def recv_file(socket, filename):
    with open('download.txt','wb') as out:
        print "Opened File: " , file.name
        inp = socket.makefile('rb')
        shutil.copyfileobj(inp, out)