Python で Web サイトまたは IP アドレスに ping を実行するにはどうすればよいですか?
17 に答える
Matthew Dixon CowlesとJens Diemerによるこのピュア Python pingを参照してください。また、Linux で ICMP (つまり ping) ソケットを生成するには、Python が root を必要とすることも覚えておいてください。
import ping, socket
try:
ping.verbose_ping('www.google.com', count=3)
delay = ping.Ping('www.wikipedia.org', timeout=2000).do()
except socket.error, e:
print "Ping Error:", e
ソース コード自体は読みやすく、インスピレーションを得るためにverbose_ping
との実装を参照してくださいPing.do
。
何を達成したいかにもよりますが、システムの ping コマンドを呼び出すのがおそらく最も簡単です。
subprocess モジュールを使用するのがこれを行う最良の方法ですが、オペレーティング システムによって ping コマンドが異なることを覚えておく必要があります。
import subprocess
host = "www.google.com"
ping = subprocess.Popen(
["ping", "-c", "4", host],
stdout = subprocess.PIPE,
stderr = subprocess.PIPE
)
out, error = ping.communicate()
print out
シェルエスケープ文字について心配する必要はありません。例えば..
host = "google.com; `echo test`
..echoコマンドを実行しません。
out
ここで、実際に ping の結果を取得するために、変数を解析できます。出力例:
round-trip min/avg/max/stddev = 248.139/249.474/250.530/0.896 ms
正規表現の例:
import re
matcher = re.compile("round-trip min/avg/max/stddev = (\d+.\d+)/(\d+.\d+)/(\d+.\d+)/(\d+.\d+)")
print matcher.search(out).groups()
# ('248.139', '249.474', '250.530', '0.896')
繰り返しますが、出力はオペレーティング システム (および のバージョンping
) によって異なることに注意してください。これは理想的ではありませんが、多くの状況 (スクリプトが実行されるマシンがわかっている場合) では問題なく機能します。
Noah Gift のプレゼンテーション 、 Creating Agile Commandline Tools With Python を見つけることができます。その中で彼は、サブプロセス、キュー、およびスレッド化を組み合わせて、ホストに同時に ping を実行し、プロセスを高速化できるソリューションを開発しました。以下は、コマンド ライン解析やその他の機能を追加する前の基本的なバージョンです。このバージョンと他のバージョンのコードはここにあります
#!/usr/bin/env python2.5
from threading import Thread
import subprocess
from Queue import Queue
num_threads = 4
queue = Queue()
ips = ["10.0.1.1", "10.0.1.3", "10.0.1.11", "10.0.1.51"]
#wraps system ping command
def pinger(i, q):
"""Pings subnet"""
while True:
ip = q.get()
print "Thread %s: Pinging %s" % (i, ip)
ret = subprocess.call("ping -c 1 %s" % ip,
shell=True,
stdout=open('/dev/null', 'w'),
stderr=subprocess.STDOUT)
if ret == 0:
print "%s: is alive" % ip
else:
print "%s: did not respond" % ip
q.task_done()
#Spawn thread pool
for i in range(num_threads):
worker = Thread(target=pinger, args=(i, queue))
worker.setDaemon(True)
worker.start()
#Place work in queue
for ip in ips:
queue.put(ip)
#Wait until worker threads are done to exit
queue.join()
彼は以下の著者でもあります: Python for Unix and Linux System Administration
http://ecx.images-amazon.com/images/I/515qmR%2B4sjL._SL500_AA240_.jpg
あなたの質問が何であるかを言うのは難しいですが、いくつかの選択肢があります。
ICMP ping プロトコルを使用して文字通り要求を実行する場合は、ICMP ライブラリを取得して直接 ping 要求を実行できます。このicmplibのようなものを見つけるには、Google「Python ICMP」。scapyも見たいと思うかもしれません。
これは、 を使用するよりもはるかに高速ですos.system("ping " + ip )
。
ボックスが稼働しているかどうかを一般的に「ping」する場合は、ポート 7 でエコー プロトコルを使用できます。
エコーの場合、ソケットライブラリを使用して IP アドレスとポート 7 を開きます。そのポートに何かを書き込み、キャリッジ リターン ( "\r\n"
) を送信してから、応答を読み取ります。
Web サイトが実行されているかどうかを確認するために Web サイトに "ping" を実行する場合は、ポート 80 で http プロトコルを使用する必要があります。
Web サーバーを適切にチェックするには、urllib2を使用して特定の URL を開きます。(/index.html
は常に人気があります)、応答を読んでください。
「traceroute」や「finger」など、「ping」にはさらに多くの潜在的な意味があります。
インスピレーションとして、私はこのように似たようなことをしました:
import urllib
import threading
import time
def pinger_urllib(host):
"""
helper function timing the retrival of index.html
TODO: should there be a 1MB bogus file?
"""
t1 = time.time()
urllib.urlopen(host + '/index.html').read()
return (time.time() - t1) * 1000.0
def task(m):
"""
the actual task
"""
delay = float(pinger_urllib(m))
print '%-30s %5.0f [ms]' % (m, delay)
# parallelization
tasks = []
URLs = ['google.com', 'wikipedia.org']
for m in URLs:
t = threading.Thread(target=task, args=(m,))
t.start()
tasks.append(t)
# synchronization point
for t in tasks:
t.join()
を使用した短いスニペットを次に示しsubprocess
ます。このcheck_call
メソッドは、成功の場合は 0 を返すか、例外を発生させます。このように、ping の出力を解析する必要はありません。shlex
コマンドライン引数を分割するために使用しています。
import subprocess
import shlex
command_line = "ping -c 1 www.google.comsldjkflksj"
args = shlex.split(command_line)
try:
subprocess.check_call(args,stdout=subprocess.PIPE,stderr=subprocess.PIPE)
print "Website is there."
except subprocess.CalledProcessError:
print "Couldn't get a ping."
私はあなたに役立つと思うライブラリを開発しています。これは icmplib (インターネット上にある同名の他のコードとは無関係) と呼ばれ、Python での ICMP プロトコルの純粋な実装です。
これは完全にオブジェクト指向であり、従来の ping、multiping、traceroute などの単純な機能に加えて、ICMP プロトコルに基づいてアプリケーションを開発したい人向けの低レベルのクラスとソケットを備えています。
その他のハイライトは次のとおりです。
- root 権限なしで実行できます。
- ICMP パケットのペイロードやトラフィック クラス (QoS) など、多くのパラメータをカスタマイズできます。
- クロスプラットフォーム: Linux、macOS、および Windows でテスト済み。
- サブプロセスで行われた呼び出しとは異なり、高速で、CPU / RAM リソースをほとんど必要としません。
- 軽量で、追加の依存関係に依存しません。
インストールするには (Python 3.6+ が必要):
pip3 install icmplib
ping 関数の簡単な例を次に示します。
host = ping('1.1.1.1', count=4, interval=1, timeout=2, privileged=True)
if host.is_alive:
print(f'{host.address} is alive! avg_rtt={host.avg_rtt} ms')
else:
print(f'{host.address} is dead')
root 権限なしでライブラリを使用する場合は、"privileged" パラメータを False に設定します。
プロジェクトページで完全なドキュメントを見つけることができます: https://github.com/ValentinBELYN/icmplib
このライブラリが役立つことを願っています。
ファイル名を読み取ると、ファイルには次のように 1 行に 1 つの URL が含まれます。
http://www.poolsaboveground.com/apache/hadoop/core/
http://mirrors.sonic.net/apache/hadoop/core/
コマンドを使用:
python url.py urls.txt
結果を取得します。
Round Trip Time: 253 ms - mirrors.sonic.net
Round Trip Time: 245 ms - www.globalish.com
Round Trip Time: 327 ms - www.poolsaboveground.com
ソースコード (url.py):
import re
import sys
import urlparse
from subprocess import Popen, PIPE
from threading import Thread
class Pinger(object):
def __init__(self, hosts):
for host in hosts:
hostname = urlparse.urlparse(host).hostname
if hostname:
pa = PingAgent(hostname)
pa.start()
else:
continue
class PingAgent(Thread):
def __init__(self, host):
Thread.__init__(self)
self.host = host
def run(self):
p = Popen('ping -n 1 ' + self.host, stdout=PIPE)
m = re.search('Average = (.*)ms', p.stdout.read())
if m: print 'Round Trip Time: %s ms -' % m.group(1), self.host
else: print 'Error: Invalid Response -', self.host
if __name__ == '__main__':
with open(sys.argv[1]) as f:
content = f.readlines()
Pinger(content)
import subprocess as s
ip=raw_input("Enter the IP/Domain name:")
if(s.call(["ping",ip])==0):
print "your IP is alive"
else:
print "Check ur IP"
Windows と Linux の両方で動作する前述のスクリプトの更新バージョンは、ここにあります。
system ping コマンドを使用して、ホストのリストに ping を実行します。
import re
from subprocess import Popen, PIPE
from threading import Thread
class Pinger(object):
def __init__(self, hosts):
for host in hosts:
pa = PingAgent(host)
pa.start()
class PingAgent(Thread):
def __init__(self, host):
Thread.__init__(self)
self.host = host
def run(self):
p = Popen('ping -n 1 ' + self.host, stdout=PIPE)
m = re.search('Average = (.*)ms', p.stdout.read())
if m: print 'Round Trip Time: %s ms -' % m.group(1), self.host
else: print 'Error: Invalid Response -', self.host
if __name__ == '__main__':
hosts = [
'www.pylot.org',
'www.goldb.org',
'www.google.com',
'www.yahoo.com',
'www.techcrunch.com',
'www.this_one_wont_work.com'
]
Pinger(hosts)
Python 2.7 でテストされ、正常に動作します。成功した場合はミリ秒単位で ping 時間を返し、失敗した場合は False を返します。
import platform,subproccess,re
def Ping(hostname,timeout):
if platform.system() == "Windows":
command="ping "+hostname+" -n 1 -w "+str(timeout*1000)
else:
command="ping -i "+str(timeout)+" -c 1 " + hostname
proccess = subprocess.Popen(command, stdout=subprocess.PIPE)
matches=re.match('.*time=([0-9]+)ms.*', proccess.stdout.read(),re.DOTALL)
if matches:
return matches.group(1)
else:
return False