I am following this tutorial on sockets, and I was doing fine until the teacher ran the program again in the text editor at 34 minutes 44 seconds. On my end, I received an error message saying, socket.error: [Errno 48] Address already in use. I am using a Macbook, and my text editor is Atom. I would appreciate any help I can get with fixing or addressing this error!
Traceback
Traceback (most recent call last):
File "/Users/lyons/Documents/sockets/server.py", line 16, in <module>
server.bind(ADDR)
File "/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/socket.py", line 228, in meth
return getattr(self._sock,name)(*args)
socket.error: [Errno 48] Address already in use
[Finished in 0.393s]
server.py
import socket
import threading
HEADER = 64
PORT = 5050
SERVER = socket.gethostbyname(socket.gethostname())
ADDR = (SERVER, PORT)
FORMAT = 'utf-8'
DISCONNECT_MESSAGE = "!DISCONNECT"
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server.bind(ADDR)
def handle_client(conn, addr):
print("[NEW CONNECTION] {addr} connected.")
connected = True
while connected:
msg_length = conn.recv(HEADER).decode(FORMAT)
msg_length = int(msg_length)
msg = conn.recv(msg_length).decode(FORMAT)
if msg == DISCONNECT_MESSAGE:
connected = False
print("[{}] {}".format(addr, msg))
conn.close()
def start():
server.listen()
print("[LISTENING] Server is listening on {}".format(SERVER))
while True:
conn, addr = server.accept() # BLOCKING LINE OF CODE
thread = threading.Thread(target=handle_client, args=(conn, addr))
thread.start()
print("[ACTIVE CONNECTIONS] {threading.activeCount() - 1}")
print("[STARTING] server is starting...")
start()
client.py
import socket
HEADER = 64
PORT = 5050
FORMAT = 'utf-8'
DISCONNECT_MESSAGE = "!DISCONNECT"
SERVER = socket.gethostbyname(socket.gethostname())
ADDR = (SERVER, PORT)
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client.connect(ADDR)