2017-03-05 55 views
2

我是Linux新手,目前在我的第二台笔记本电脑上运行Python脚本时遇到问题(奇怪的是,在我的另一台机器上脚本运行没有任何问题)Python脚本返回 - > socket.error:[Errno 98]已经在使用的地址

的脚本被执行:发生

import socket 

class DNSQuery: 
def __init__(self, data): 
self.data=data 
self.dominio='' 

tipo = (ord(data[2]) >> 3) & 15 
if tipo == 0: 
ini=12 
lon=ord(data[ini]) 
while lon != 0: 
self.dominio+=data[ini+1:ini+lon+1]+'.' 
ini+=lon+1 
lon=ord(data[ini]) 

def respuesta(self, ip): 
packet='' 
if self.dominio: 
    packet+=self.data[:2] + "\x81\x80" 
    packet+=self.data[4:6] + self.data[4:6] + '\x00\x00\x00\x00' 
    packet+=self.data[12:] 
    packet+='\xc0\x0c' 
    packet+='\x00\x01\x00\x01\x00\x00\x00\x3c\x00\x04' 
    packet+=str.join('',map(lambda x: chr(int(x)), ip.split('.'))) 
    return packet 

if __name__ == '__main__': 
ip='192.168.1.1' 
print 'pyminiDwebconfNS:: dom.query. 60 IN A %s' % ip 

udps = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) 
udps.bind(('',53)) 

try: 
while 1: 
    data, addr = udps.recvfrom(1024) 
    p=DNSQuery(data) 
    udps.sendto(p.respuesta(ip), addr) 
    print 'Request: %s -> %s' % (p.dominio, ip) 
except KeyboardInterrupt: 
print 'Finalizando' 
udps.close() 

以下错误:

[email protected] /m/r/B4A9-733B# python dns.py 

pyminifakeDwebconfNS:: dom.query. 60 IN A 192.168.1.1 
Traceback (most recent call last): 
File "dns.py", line 33, in <module> 
udps.bind(('',53)) 
File "/usr/lib/python2.7/socket.py", line 228, in meth 
return getattr(self._sock,name)(*args) 
socket.error: [Errno 98] Address already in use 

我想已经改变IP地址,但没有运气,无论w ^这些IP设置发生错误。

然后我用 “netstat的-an” 检查,看看是否192.168.1.1被阻止,但未能找到任何

B4A9-733B#的netstat -an

Active Internet connections (servers and established) 
Proto Recv-Q Send-Q Local Address   
Foreign Address    State  
tcp  0  0 127.0.0.1:5939   0.0.0.0:*     
tcp  0  0 127.0.0.1:53   0.0.0.0:*     
tcp  0  0 127.0.0.2:53   0.0.0.0:*     
tcp  0  0 127.0.0.1:8118   0.0.0.0:*     
tcp  0  0 127.0.0.1:9050   0.0.0.0:*     
tcp  0  0 127.0.0.1:9051   0.0.0.0:*     
tcp  0  1 192.168.179.135:57008 151.101.193.69:80   
tcp  0 2824 192.168.179.135:57376 151.101.193.69:80  
tcp  0  1 192.168.179.135:34152 151.101.65.69:80   
tcp  0 644 192.168.179.135:50030 151.101.129.69:80  
tcp  0  1 192.168.179.135:34154 151.101.65.69:80   
tcp  0  0 127.0.0.1:9050   127.0.0.1:34242   
tcp  0  0 192.168.179.135:54362 178.62.201.15:9090  
tcp  0  1 192.168.179.135:57014 151.101.193.69:80   
tcp6  0  0 ::1:8118    :::*       
udp  0  0 127.0.0.1:47649   127.0.0.1:53    
udp  0 2560 0.0.0.0:41994          
udp  0  0 127.0.0.1:50619   127.0.0.1:53    
udp  0  0 127.0.0.1:36289   127.0.0.1:53    

我的问题是我不要完全理解报告的错误以及我可以检查/更改以解决此问题。希望你们可以提供一些额外的想法来解决这个问题。

感谢 奇美拉

+0

请缩进您的代码,以便阅读和帮助。 –

回答

1

这条线:

udps.bind(('',53)) 

是有约束力的插座,所以你可以听INADDR_ANY - 任何传入主机。它有什么也没有做与ip地址“192.168.1.1”。正在使用的地址实际上是(localhost, 53)

您的错误意味着您已经在端口53上运行程序(它已被占用),因此您无法将其绑定到udp端口。你可以从netstat中看到端口被占用的地方。

尝试终止您的计算机上端口53上运行的进程,然后重试。

相关问题