86

Python で Web サイトまたは IP アドレスに ping を実行するにはどうすればよいですか?

4

17 に答える 17

83

Matthew Dixon CowlesJens 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

于 2008-11-25T12:39:12.157 に答える
44

何を達成したいかにもよりますが、システムの 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) によって異なることに注意してください。これは理想的ではありませんが、多くの状況 (スクリプトが実行されるマシンがわかっている場合) では問題なく機能します。

于 2008-11-25T10:49:58.900 に答える
40

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

于 2008-11-25T12:28:42.570 に答える
9

あなたの質問が何であるかを言うのは難しいですが、いくつかの選択肢があります。

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」にはさらに多くの潜在的な意味があります。

于 2008-11-25T11:12:56.840 に答える
8

インスピレーションとして、私はこのように似たようなことをしました:

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()
于 2009-07-22T12:59:52.790 に答える
6

を使用した短いスニペットを次に示し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."
于 2012-09-19T07:35:43.840 に答える
4

私はあなたに役立つと思うライブラリを開発しています。これは 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

このライブラリが役立つことを願っています。

于 2020-11-21T20:05:29.277 に答える
3

ファイル名を読み取ると、ファイルには次のように 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)
于 2012-12-01T13:14:48.080 に答える
2
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"
于 2015-03-06T10:29:11.537 に答える
1

Windows と Linux の両方で動作する前述のスクリプトの更新バージョンは、ここにあります。

于 2009-11-16T12:10:29.630 に答える
0

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)
于 2008-11-25T17:12:11.640 に答える
-1

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
于 2015-04-11T17:10:06.287 に答える