Search code examples
pythonsshparamikocisco

Commands written to Cisco shell with Paramiko do not get executed


I'm trying to configure a Cisco router's IP address remotely using Paramiko, but nothing I do seems to work! Please can someone look at my code and tell me what I'm doing wrong?

Thanks in advance :)

import paramiko
import socket 
import sys
import time

ip_address = "192.168.56.101"
port = 22
username = "cisco"
password = "cisco123!"
session = ""

def SSHConnect():
    global session
    print("\n------Attempting to connect to remote server------\n")
    session = paramiko.SSHClient() #stores ssh client as var "session"
    session.set_missing_host_key_policy(paramiko.AutoAddPolicy()) #adds missing policy automatically on first connection
    try:
        session.connect(ip_address, port,username,password,timeout=5)
    except socket.error:
        print("---Error! Unable to connect using supplied IP address / port - Program is now exiting...")
        sys.exit()
    except paramiko.ssh_exception.AuthenticationException:
        print("---Error! Supplied login information rejected by remote server - Program is now exiting...")
        sys.exit()

    print("Connected successfully!")
    
def conf_router():
    print("configuring router....")
    session_shell = session.invoke_shell()
    session_shell.send("config terminal")
    time.sleep(1)

    session_shell.send("int gigabitEthernet1")
    time.sleep(1)

    session_shell.send("ip address 192.168.5.2 255.255.255.0")
    time.sleep(1)

    
if __name__ == "__main__":
    SSHConnect()
    conf_router()
      

Solution

  • You have to "submit" your commands with enter/new-line (\n):

    session_shell.send("config terminal\n")
    

    A related question:
    Paramiko exec_command with multiple commands on Cisco router not providing any output