Создание нескольких SSH-соединений одновременно с использованием Paramiko - PullRequest
17 голосов
/ 15 августа 2010

Приведенный ниже код запускает grep на одной машине через SSH и печатает результаты:

import sys, os, string
import paramiko

cmd = "grep -h 'king' /opt/data/horror_20100810*"

ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect('10.10.3.10', username='xy', password='xy')
stdin, stdout, stderr = ssh.exec_command(cmd)
stdin.write('xy\n')
stdin.flush()

print stdout.readlines()

Как я могу grep пять машин одновременно (чтобы у меня не было большой задержки), чем положитьвсе это в пяти переменных и распечатать их все.

Ответы [ 2 ]

33 голосов
/ 15 августа 2010

Вам нужно будет помещать вызовы в отдельные потоки (или процессы, но это было бы излишним), что, в свою очередь, требует, чтобы код был в функции (что в любом случае является хорошей идеей: не иметь значительного кода вверхний уровень модуля).

Например:

import sys, os, string, threading
import paramiko

cmd = "grep -h 'king' /opt/data/horror_20100810*"

outlock = threading.Lock()

def workon(host):

    ssh = paramiko.SSHClient()
    ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
    ssh.connect(host, username='xy', password='xy')
    stdin, stdout, stderr = ssh.exec_command(cmd)
    stdin.write('xy\n')
    stdin.flush()

    with outlock:
        print stdout.readlines()

def main():
    hosts = ['10.10.3.10', '10.10.4.12', '10.10.2.15', ] # etc
    threads = []
    for h in hosts:
        t = threading.Thread(target=workon, args=(h,))
        t.start()
        threads.append(t)
    for t in threads:
        t.join()

main()

Если бы у вас было много более пяти хостов, я бы рекомендовал вместо этого использовать архитектуру «пула потоков» и очередь рабочих блоков.,Но всего за пять проще придерживаться модели «выделенного потока» (тем более что в стандартной библиотеке нет пула потоков, поэтому вам потребуется сторонний пакет, такой как threadpool ...или много тонкого собственного кода, конечно; -).

0 голосов
/ 02 сентября 2016

Просто запустите все в цикле for и не забудьте закрыть стандартный ввод перед переходом к следующей итерации. То есть после строки stdin.flush() добавить строку stdin.close()

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...