我编程应该可以解决多个主机名到使用多线程的IP地址的脚本。的Python socket.gethostbyname_ex()多线程失败
但是,它未能在一些随机点冻结。这怎么解决?
num_threads = 100
conn = pymysql.connect(host='xx.xx.xx.xx', unix_socket='/tmp/mysql.sock', user='user', passwd='pw', db='database')
cur = conn.cursor()
def mexec(befehl):
cur = conn.cursor()
cur.execute(befehl)
websites = ['facebook.com','facebook.org' ... ... ... ...] \#10.000 websites in array
queue = Queue()
def getips(i, q):
while True:
#--resolve IP--
try:
result = socket.gethostbyname_ex(site)
print(result)
mexec("UPDATE sites2block SET ip='"+result+"', updated='yes' ") #puts site in mysqldb
except (socket.gaierror):
print("no ip")
mexec("UPDATE sites2block SET ip='no ip', updated='yes',")
q.task_done()
#Spawn thread pool
for i in range(num_threads):
worker = Thread(target=getips, args=(i, queue))
worker.setDaemon(True)
worker.start()
#Place work in queue
for site in websites:
queue.put(site)
#Wait until worker threads are done to exit
queue.join()
你会得到什么错误? – 2012-02-08 13:59:17
sry,忘了接受!我没有得到具体的错误,脚本运行,并在某些时候只是冻结而不显示任何具体的错误。然后我必须杀死壳。 – user670186 2012-02-08 14:10:31
这个例子是不完整的 - 什么是mexec? – 2012-02-08 14:15:47