web-dev-qa-db-ja.com

Python socket.error:[Errno 111]接続が拒否されました

ソケットを使用してファイル転送用のプログラムを作成しようとしています。サーバー側のコードは正常に動作しています。ただし、クライアント側で次のエラーが表示されます

Traceback (most recent call last):
File "client.py", line 54, in <module>
uploadFiles(directory)
File "client.py", line 36, in uploadFiles
transferFile(fname)
File "client.py", line 13, in transferFile     
cs.connect((Host, 36258))
File "/usr/lib/python2.7/socket.py", line 224, in meth
return getattr(self._sock,name)(*args)
socket.error: [Errno 111] Connection refused

私のコードは次のとおりです

import os
import socket

def transferFile(fname):
   Host = '127.0.0.1'
   CPORT = 36258
   MPORT = 36250
   FILE = fname
   cs = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
   cs.connect((Host, 36258))
   cs.send("SEND " + FILE)
   cs.close()
   ms = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
   ms.connect((Host, MPORT))
   f = open(FILE, "rb")
   data = f.read()
   f.close()
   ms.send(data)
   ms.close()

def uploadFiles(directory):
   home = os.getenv("HOME")
   folder = str(home + "/" + directory)
   os.chdir(folder)
   dirList = os.listdir(folder)
   print dirList
   for fname in dirList:
       if fname.endswith('.bin'):
           transferFile(fname)

os.chdir(os.getenv("HOME"))
directory = "testdownload"
if not os.path.exists(directory):
   os.makedirs(directory)
 os.chdir(directory)

uploadFiles(directory)

GoogleやStack Overflowの他の投稿で助けを探してみましたが、誰も助けませんでした。誰か助けてくれますか?コードの一部のみを貼り付けたため、行番号が異なる場合があります

20
hld619

問題は、(あなたが考え出したように)接続しようとしたときにサーバー側でポート36250が開いていなかったことです(したがって、接続は拒否されました)。別の接続でSENDコマンドを受信した後、サーバーがこのソケットを開くはずだったのを見ることができますが、どうやら「クライアント側と同期して[開かない]」ようでした。

まあ、主な理由は、同期がまったくなかったことでしょう。呼び出し:

cs.send("SEND " + FILE)
cs.close()

oSバッファーにデータを配置するだけです。 closeはおそらくデータをフラッシュしてネットワークにプッシュしますが、データがサーバーに到達する前にほぼ確実に戻ります。 sleepの後にcloseを追加すると、問題を軽減できる場合がありますが、これは同期ではありません

正しい解決策は、確認サーバーが接続を開いたことです。これには、サーバーが何らかのメッセージを送り返す必要があります(たとえば、OK、またはそれ以上のPORT 36250は接続先を示します)。これにより、サーバーが既にリッスンしていることが確認されます。

もう1つはsendの戻り値をチェックして、バッファーから何バイトが取り出されたかを確認する必要があります。または sendall を使用します。

(この遅い回答で邪魔してすみませんが、これは交通量の多い質問であることがわかり、コメントセクションの睡眠のアイデアは本当に好きではありませんでした。)

18
tomasz