2017-03-05 17 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上運行的進程,然後重試。

相關問題