[Errno 48] Address already in use 解决方法

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Megustas_JJC/article/details/79027376

在进行socket编程时,我们在运行server端代码的时候遇到了如下的问题:
这里写图片描述

显示地址已经被占用,那么我们如何解决这个问题?

首先我们看一下server端的代码:

s = socket.socket()
host = socket.gethostname()
port = 12345
s.bind((host,port))
s.listen(5)

Use lsof -i :5000 This will give you a list of processes using the port if any. Once the list of processes is given, use the id on the PID column to terminate the process: e.g kill 379

我们可以使用lsof指令来找出正在使用此端口的进程,然后根据PID(ProcessID,进程ID)进行kill操作即可(PID就是各进程的身份标识,程序一运行系统就会自动分配给进程一个独一无二的PID。进程中止后PID被系统回收,可能会被继续分配给新运行的程序)。

例如:
这里写图片描述

当然这不是根本的解决为何stop了server.py程序,但是还被占用的问题。究其原因,是socket选项在捣鬼。下面是IBM官网上对这一情况的具体解释,参见http://www.ibm.com/developerworks/cn/linux/l-sockpit/
bind 普遍遭遇的问题是试图绑定一个已经在使用的端口。该陷阱是也许没有活动的套接字存在,但仍然禁止绑定端口(bind 返回 EADDRINUSE),它由 TCP 套接字状态 TIME_WAIT 引起。该状态在套接字关闭后约保留 2 到 4 分钟。在 TIME_WAIT 状态退出之后,套接字被删除,该地址才能被重新绑定而不出问题。
等待 TIME_WAIT 结束可能是令人恼火的一件事,特别是如果您正在开发一个套接字服务器,就需要停止服务器来做一些改动,然后重启。幸运的是,有方法可以避开 TIME_WAIT 状态。可以给套接字应用 SO_REUSEADDR 套接字选项,以便端口可以马上重用。也可以参见如下博客: http://blog.csdn.net/piaojun_pj/article/details/6098438

猜你喜欢

转载自blog.csdn.net/Megustas_JJC/article/details/79027376