Застрял с функцией read_all () в Python? - PullRequest
0 голосов
/ 13 января 2019

Я написал небольшой код на python для автоматизации задач настройки на нескольких маршрутизаторах Cisco с использованием библиотеки telnet. В первой итерации все работает нормально, проблема в том, что у меня истекло время ожидания во второй итерации функции read_all (). Если я удалю параметр времени ожидания из функции telnetlib.Telnet (), я застряну навсегда в одной и той же итерации.

from telnet import telnet

import xlrd

class handler:
 excel_sheet=None
 ipv4_devices=None
 ipv6_devices=None
 config=None
 telnet=None

def __init__(self):
 self.excel_sheet = xlrd.open_workbook("ipv4_devices.xlsx")
 self.config=open("config.txt","r")
 output_init = open("output.txt","w+")
 output_init.write("")
 output_init.close()  

def execute(self):
 row = None
 column = None
 self.ipv4_devices = self.excel_sheet.sheet_by_index(0)
 for row in range(self.ipv4_devices.nrows-1):
  self.telnet = telnet(self.ipv4_devices.cell_value(row+1,0),self.ipv4_devices.cell_value(row+1,1), self.ipv4_devices.cell_value(row+1,2), self.ipv4_devices.cell_value(row+1,3), self.config)
 self.telnet.do_telnet()
 self.telnet=None
self.config.close()

Выше находится мой файл Handler.py, который, в свою очередь, вызывает мой файл telnet.py, содержащий фактический код telnet.

import sys
import telnetlib

class telnet:
 ipv4_address=None
 port=0
 username=None 
 passphrase=None
 config=None

 def __init__(self, ipv4_address=None, port=23, username=None, passphrase=None, config=None):
  if (ipv4_address is not None) and (username is not None) and (passphrase is not None) and (config is not None) : 
   self.ipv4_address = ipv4_address
   self.port = port
   self.username = username
   self.passphrase = passphrase
   self.config = config
  else:
   exit()  

 def do_telnet(self):
  output = open("output.txt","a")
  remote= telnetlib.Telnet(self.ipv4_address,int(self.port))
  remote.read_until("Username: ")
  remote.write(self.username.encode('ascii')+"\n")
  remote.read_until("Password: ")
  remote.write(self.passphrase.encode('ascii')+"\n")
  remote.write(self.config.read().encode('ascii')+"\n")
  output.write(remote.read_all()+"\n"+"  -------  "+"\n")
  remote.close()
  output.close()

Ниже приведена ошибка, которую я получаю, когда истекло время ожидания

Traceback (most recent call last):
  File "Automate.py", line 5, in <module>
    automate_it.execute()
  File "/home/abdultayyeb/Desktop/Automation/handler.py", line 30, in execute
    self.telnet.do_telnet()
  File "/home/abdultayyeb/Desktop/Automation/telnet.py", line 31, in do_telnet
    output.write(remote.read_all()+"\n"+"  -------  "+"\n")
  File "/usr/lib/python2.7/telnetlib.py", line 385, in read_all
    self.fill_rawq()
  File "/usr/lib/python2.7/telnetlib.py", line 576, in fill_rawq
    buf = self.sock.recv(50)
  socket.timeout: timed out

1 Ответ

0 голосов
/ 31 января 2019

Я предлагаю переписать это, чтобы использовать netmiko, так как он будет обрабатывать особенности работы с Cisco IOS.

Ключ должен указать тип вашего устройства как cisco_ios_telnet.

Это даст дополнительное преимущество: вам не нужно будет переписывать ваш код при конвертации ваших систем в SSH. Вы бы просто изменили тип устройства с cisco_ios_telnet на cisco_ios

https://pynet.twb -tech.com / блог / автоматизация / netmiko.html

...