zoukankan      html  css  js  c++  java
  • python 远程执行命令

    1.简单版

    # coding: utf-8
    
    import paramiko
    import re
    from time import sleep
    
    def ssh():
        ssh = paramiko.SSHClient()
        ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())    #指定当对方主机没有本机公钥的情况时应该怎么办,AutoAddPolicy表示自动在对方主机保存下本机的秘钥
        ssh.connect('172.16.1.5',22,'linyouyi','123456')    #SSH端口默认22,可改
        stdin,stdout,stderr = ssh.exec_command("df -hl")    #这三个得到的都是类文件对象
        outmsg,errmsg = stdout.read(),stderr.read()    #读一次之后,stdout和stderr里就没有内容了,所以一定要用变量把它们带的信息给保存下来,否则read一次之后就没有了
        #outmsg = str(outmsg)
        #print(outmsg.replace("\n","\r\n"))
        print(outmsg.decode())
        print(errmsg)
        if errmsg == "":
            print(outmsg)
        ssh.close()
    if __name__ == '__main__':
        ssh()

    2.封装版

    # coding: utf-8
    
    import paramiko
    import re
    from time import sleep
    
    # 定义一个类,表示一台远端linux主机
    class Linux(object):
        # 通过IP, 用户名,密码,超时时间初始化一个远程Linux主机
        def __init__(self, ip, username, password, timeout=30):
            self.ip = ip
            self.username = username
            self.password = password
            self.timeout = timeout
            # transport和chanel
            self.t = ''
            self.chan = ''
            # 链接失败的重试次数
            self.try_times = 3
    
        # 调用该方法连接远程主机
        def connect(self):
            while True:
                # 连接过程中可能会抛出异常,比如网络不通、链接超时
                try:
                    self.t = paramiko.Transport(sock=(self.ip, 22))
                    self.t.connect(username=self.username, password=self.password)
                    self.chan = self.t.open_session()
                    self.chan.settimeout(self.timeout)
                    self.chan.get_pty()
                    self.chan.invoke_shell()
                    # 如果没有抛出异常说明连接成功,直接返回
                    print(u'连接%s成功' % self.ip)
                    # 接收到的网络数据解码为str
                    print(self.chan.recv(65535).decode('utf-8'))
                    return
                # 这里不对可能的异常如socket.error, socket.timeout细化,直接一网打尽
                except Exception as e1:
                    if self.try_times != 0:
                        print(u'连接%s失败,进行重试' %self.ip)
                        self.try_times -= 1
                    else:
                        print(u'重试3次失败,结束程序')
                        exit(1)
    
        # 断开连接
        def close(self):
            self.chan.close()
            self.t.close()
    
        # 发送要执行的命令
        def send(self, cmd):
            cmd += '
    '
            # 通过命令执行提示符来判断命令是否执行完成
            p = re.compile(r']$')
    
            result = ''
            # 发送要执行的命令
            self.chan.send(cmd)
            # 回显很长的命令可能执行较久,通过循环分批次取回回显
            while True:
                sleep(2)
                ret = self.chan.recv(65535)
                ret = ret.decode('utf-8')
                result += ret
                if p.search(ret):
                    print(result)
                    return(result)
                    
    if __name__ == '__main__':
        host = Linux('172.16.1.5', 'linyouyi', '123456')
        host.connect()
        host.send('ll')
        host.close()
  • 相关阅读:
    【2020NOI.AC省选模拟#5】C. 光滑序列
    【2020NOI.AC省选模拟#2】A. 旋转
    【2020NOI.AC省选模拟#1】B. Trie
    Redis 配置
    Redis 删除策略
    Redis 事务
    Redis 持久化
    Redis 通用指令
    Redis 数据类型实战案例
    Redis sorted_set
  • 原文地址:https://www.cnblogs.com/linyouyi/p/11474518.html
Copyright © 2011-2022 走看看