Я использовал jedie's python ping
implementation на Windows. Я мог ошибаться, но когда пинг двух компьютеров (A и B) из отдельных потоков, ping вернет первый пинг, который он получает, независимо от источника.Python ICMP ping реализация при пинге нескольких ips из потоков?
Поскольку это может быть проблема с вилкой джедая, я reverted to the previous version. (Это версия, которую я собираюсь исследовать ниже)
Я добавил в строке кода в receive_one_ping
: (строка 134 или аналогичный)
recPacket, addr = my_socket.recvfrom(1024) # Existing line
print "dest: {}, recv addr: {}.".format(dest_addr, addr) # New line
Это позволяет увидеть адрес пинг мы получаем. (Должен быть такой же, как назначения IP, не так ли?)
Тестирование:
ping1() пингует известный автономный IP (1.2.3.4),
ping2() пингует известный онлайн-IP (192,168 .1.1 - маршрутизатор)
>>> from ping import do_one
>>> def ping1():
print "Offline:", do_one("1.2.3.4",1)
>>> ping1()
Offline: None
>>> def ping2():
print "Online:", do_one("192.168.1.1",1)
>>> ping2()
Online: dest: 192.168.1.1, recv addr: ('192.168.1.1', 0).
0.000403682590942
Теперь, если мы делаем их вместе: (Использование таймера для простоты)
>>> from threading import Timer
>>> t1 = Timer(1, ping1)
>>> t2 = Timer(1, ping2)
>>> t1.start(); t2.start()
>>> Offline:Online: dest: 192.168.1.1, recv addr: ('192.168.1.1', 0).dest: 1.2.3.4, recv addr: ('192.168.1.1', 0).
0.0004508952953870.000423517514093
Это немного искажаются (за счет печати не работает хорошо с резьбой), поэтому здесь немного яснее:
>>> Online: dest: 192.168.1.1, recv addr: ('192.168.1.1', 0).
Offline:dest: 1.2.3.4, recv addr: ('192.168.1.1', 0). # this is the issue - I assume dest should be the same as recv address?
0.000450895295387
0.000423517514093
Мои вопросы:
Можно ли воссоздать это?
Должен ли пинг вести себя следующим образом? Я предполагаю, что нет.
Есть ли существующий ICMP-пинг для python, который не будет иметь такое поведение?
В качестве альтернативы, можете ли вы придумать легкое исправление - то есть опросreceive_one_ping
, пока наш пункт назначения не соответствует нашему получателю?
Edit: Я создал вопрос на python-ping github page
Отлично, спасибо. Я думаю, что мы видим только один ответ для каждого потока, потому что 'receive_one_ping' возвращается, когда' packetID == ID', и поскольку в настоящее время они всегда имеют одинаковый идентификатор, он всегда будет возвращать первый ответ. Я думаю, что я получу поток, чтобы передать уникальный идентификатор в качестве параметра 'do_one' - я попробую' threading.current_thread(). Ident' –
А, это именно оно. Хорошо, так что эта проблема с идентификатором, вероятно, единственная проблема. Если вы предпочитаете реализацию jedie, вы можете использовать ее без изменений, пока вы передаете свой собственный идентификатор в конструктор 'Ping()'. –
'threading.current_thread(). Ident' works (Я считаю, что поток устарел): Online: id: 2688 ip: 192.168.1.1. dest: 192.168.1.1, recv addr: ('192.168.1.1', 0). 0.000427707990752 Оффлайн: id: 5492 ip: 1.2.3.4 Нет. Благодаря! –