2016-05-21 41 views
0

私はSSHをルータに集め、それぞれの情報をgrepしようとしています。ルータのIPの中には、ループから取得されたものとして有効でないものもあります。存在しないものについては、socket.timeoutエラー(明らかに)が発生していて、スクリプトはその時点で実行を終了します。私はPythonがこのエラーを無視し、残りの反復を続行します。継続コマンド/パス/を除いて、私は含まれていますが、彼らは何とか自分の仕事をやっているようには見えませんし、私はまだsocket.timeoutのエラーを取得し、スクリプトを終了しています:Paramikoを使ってsocket.timeoutエラーを無視できません

import paramiko 
import socket 
import subprocess 
import time 

site = ['sao2','mia2','par2','scs2','sin4','sjl1','syd3','tok2','tor1','wdc1','akl1','chc1','chi2','cop2','dal1','fra2'] 
csr_hostname = 'csr_1' 
csr_pass = str('*******') 
username = str('test_user') 
csrcmd = 'sh ver \n' 

f = open ("version_output.txt", 'r+') 
#********************************************************************* 
for DC in site : 
    y = str(DC) 

    mcp = socket.gethostbyname(y) 

    mcpip = mcp.split('.') 
    mcpip2 = int(mcpip[0]) 
    mcpip3 = int(mcpip[1]) 
    mcpip4 = int(mcpip[2]) 

    print (DC + ":") 
    f.write('\n') 
    f.write(DC) 
    f.write('\n=====\n') 

    for i in range(5,33): 
     x=37+(2*i) 
     mcpcsr = (str(mcpip2) + ('.') + str(mcpip3)+ ('.') + str(mcpip4)+ ('.') + str(x)) 
     fqdn1=(str(i)+'-01.'+str(DC)) 
     print i 
     ssh = paramiko.SSHClient() 
     ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) 
     ssh.connect(mcpcsr, username=username, password=csr_pass, look_for_keys = False, allow_agent = False, timeout=10) 

     router_channel = ssh.invoke_shell() 
     router_channel.settimeout(2) 


     try : 
      buff = '' 
      router_channel.send(csrcmd) 
      time.sleep(1) 
      buff = router_channel.recv(99999) 
      for item in buff.split("\n"): 
       if "Cisco IOS XE Software, Version" in item : 
        csrver = (fqdn1 + " : " + item.strip()) 
       if "Cisco IOS Software" in item : 
        csrver1 = (item.strip()) 
      print csrver 
      print csrver1 
      f.write(csrver) 
      f.write('\n') 
      f.write(csrver1) 
      f.write('\n') 
      fqdn1 = '' 
      ssh.close() 


    #********************************************************************* 

     except socket.timeout: 
      print ("bla bla") 
      pass 
      continue 

     except socket.error : 
      print ("bla bla") 
      pass 
      continue 

     except paramiko.SSHException, socket.error : 
      print ("bla bla") 
      pass 
      continue 
     except Exception : 
      print ("bla bla") 
      pass 
      continue 

    #********************************************************************* 

出力:

Traceback (most recent call last): 
    File "csrnum.py", line 36, in ? 
    ssh.connect(mcpcsr, username=username, password=csr_pass, look_for_keys = False, allow_agent = False, timeout=10) 
    File "/usr/lib/python2.4/site-packages/paramiko/client.py", line 291, in connect 
    sock.connect(addr) 
    File "<string>", line 1, in connect 
socket.timeout: timed out 

これについての洞察は非常に高く評価され、感謝の意を表します。

答えて

0

それを実感してください!例外には、ssh接続が試行されたものよりも1つインデントが設定されていました。これに対応するためにコードを少し変更しました。例外は予期したとおりに機能しています!

関連する問題