Параллельное выполнение ssh команд на серверах

При управлении большим количеством серверов часто приходится выполнять одну и ту же команду сразу на нескольких серверах (десятках/сотнях/тысячах).

Существует немало инструментов для решения этой задачи. В .io мы применяем простое решение pssh.

На Ubuntu этот инструмент доступен в пакетах:

apt-get install pssh

Перед использованием инструмента необходимо подготовить текстовые файлы с адресами серверов в формате:

10.10.0.1
10.10.0.2
10.10.0.3
...

# Список IP серверов для выполнения команд с помощью pssh

Мы активно используем микросервисную архитектуру, поэтому у нас есть десятки сервисов. Поэтому мы создали общий файл со списком всех серверов и по файлу для каждого сервиса:

  • all.txt хранит список всех серверов системы. Используется крайне редко.
  • serviceX.txt хранит список всех серверов конкретного сервиса.

Для выполнения команды на всех серверах:

parallel-ssh -h all.txt -o /tmp/ssh ls -la

# Выполнит команду "ls -la" на всех серверах из файл all.txt

Результат команды будет записан в папку /tmp/ssh — в отдельный файл для каждого сервера :

# ls -la /tmp/ssh/
-rw-r--r--     1 root     root      1238 Aug 22 16:46 10.10.0.1
-rw-r--r--     1 root     root      1269 Aug 22 16:46 10.10.0.2
-rw-r--r--     1 root     root      1110 Aug 22 16:46 10.10.0.3
-rw-r--r--     1 root     root       950 Aug 22 16:46 10.10.0.4

Для использовании авторизации по ключам:

parallel-ssh -h all.txt -x "-i key.rsa" -o /tmp/ssh ls -la

# key.rsa будет использовать для доступа ко всем серверам

Вы можете вручную задать количество потоков для выполнения команд:

parallel-ssh -h all.txt -p 10 -o /tmp/ssh ls -la

# команды будут выполняться в 10 потоков

TL;DR

Используйте pssh для выполнения команд на большом количестве серверов:

parallel-ssh -h all.txt -o /tmp/ssh ls -la

# В all.txt нужно добавить список серверов, каждый ip адрес на новой строке


Подпишитесь на Хайлоад с помощью Google аккаунта
или закройте эту хрень