При управлении большим количеством серверов часто приходится выполнять одну и ту же команду сразу на нескольких серверах (десятках/сотнях/тысячах).
Существует немало инструментов для решения этой задачи. В .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 адрес на новой строке