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

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

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

$ sudo 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 адрес на новой строке

Источник: https://ruhighload.com/post/Выполнение+ssh+команд+на+нескольких+серверах

⤧  Next post Open Graph разметка в 1С-Битрикс ⤧  Previous post Как вывести имя раздела и ссылку на него в 1С-Битрикс