От переводчика: Ссылка на эту статью была опубликована в последней официальной рассылке Docker. Думаю, я не один интересуюсь одновременно и Raspberry Pi и Docker (Swarm), поэтому предлагаю вашему вниманию перевод,
В этом посте мы расскажем насколько легко можно установить Swarm на ваших Raspberry Pi и настроить на них Swarm кластер с помощью Docker Machine.
Мы построили небольшую башню Pi из трёх Raspberry Pi 2 Model B и собрали их в кластер Docker Swarm.
Как можно видеть на фотографии, мы поставили три Распберри Пи на пятипортовый свич D-Link. Все четыре устройства питаются от 4ёх USB-портового зарядного устройства. Это позволяет башне быть очень устойчивой, но вместе с тем переносной — из внешних проводов имеются только один провод питания и один сетевой кабель.
Для вашего удобства, мы собрали использованные компоненты в один список покупок на Amazon. (Примечание переводчика: из всего списка осталось только два пункта, остальные куда-то очень быстро делись с Амазона.)
Необходимые материалы
В этом тьюториале все три шага ти выполним на Маке. Для этого нам потребуются три утилиты:
Утилита flash для записи образов SD карт для всех Raspberry Pi.
Клиент Docker, который находится на расстоянии одной установки brew.
Бинарник Docker Machine с драйвером hypriot.
Запишите карты
Сначала нам нужно установить карты с предустановленным Docker. На компьютере с мак или Линукс, можно воспользоваться нашей маленькой утилитой командной строки flash чтобы подготовить все три карты с помощью простых комманд:
$ flash --hostname pi1 http://downloads.hypriot.com/hypriot-rpi-20150416-201537.img.zip
$ flash --hostname pi2 http://downloads.hypriot.com/hypriot-rpi-20150416-201537.img.zip
$ flash --hostname pi3 http://downloads.hypriot.com/hypriot-rpi-20150416-201537.img.zip
Затем вставьте карты во все устройства Raspberry Pi и загрузитесь с них. Через некоторое время, они появятся с разными именами хостов.
Получите IP адреса
Наши SD образы тоже запускают avahi-deamon чтобы объявить имя хостов через mDNS. Поэтому каждая из малин доступна через
pi1.local
, pi2.local
и pi3.local
. Docker Machine не может разрешить эти имена хостов на данный момент, поэтому нам необходимо получить адреса IP для малин вручную.$ ping -c 1 pi1.local
$ ping -c 1 pi2.local
$ ping -c 1 pi3.local
Для этого примера представим, что три наших адреса это
92.168.1.101, 102
и 103
.Введите публичный ключ SSH
Docker Machine подключается к каждой Raspberry Pi через SSH. Вам потребуется ввести публичный ключ SSH чтобы не вводить пароль для пользователя
root
. Существует специальная утилита чтобы вводить публичный ключ SSH для удаленной машины под названием ssh-copy-id
. Возможно вам потребуется сначала ее установить.$ ssh-copy-id root@192.168.1.101
$ ssh-copy-id root@192.168.1.102
$ ssh-copy-id root@192.168.1.103
Для каждой из приведенных выше команд вам будет нужно ввести пароль
hypriot
для пользователя root.Создайте Docker машины
Для следующего шага мы воспользуемся драйвером Docker Machine чтобы подключится к устройствам Raspberry Pi Hypriot. Наш драйвер hypriot пока не интегрирован в официальный бинарник Docker Machine. Поэтому потребуется скачать бинарник
docker-machine
с драйвером hypriot.$ curl -o docker-machine http://downloads.hypriot.com/docker-machine_0.4.0-dev_darwin-amd64
$ chmod +x ./docker-machine
Скачайте файл в текущую директорию и сделайте его выполняемым. Возможно вам потребуется перенести его в другой каталог в
PATH
чтобы использовать его из других директорий.Создайте токен Swarm
Кластер Docker Swarm использует уникальный идентификатор кластера, который позволяет отдельным агентам сворма находить друг друга. Нам потребуется такой идентификатор чтобы создать Docker Swarm.
Это можно сделать из shell:
$ export TOKEN=$(for i in $(seq 1 32); do echo -n $(echo "obase=16; $(($RANDOM % 16))" | bc); done; echo)
$ echo $TOKEN
В этом примере мы используем
$ export TOKEN=babb1eb00bdecadedec0debabb1eb00b
Если у вас уже есть запущенный контейнер с Docker Swarm, вы так же можете создать новый идентификатор кластера командой
docker run --rm hypriot/rpi-swarm create
. Мы воспользовались командой выше чтобы не вдаваться в проблему курицы и яйца. Создайте Swarm Master
Теперь создадим Docker Swarm Master на первой Raspberry Pi с нашим сгенерированным идентификатором кластера
$ ./docker-machine create -d hypriot --swarm --swarm-master --swarm-discovery token://$TOKEN --hypriot-ip-address 192.168.1.101 pi1
Эта команда подключится к малине «pi1», возьмет контроль над демоном докер с помошью TLS и скачает Docker образ
hypriot/rpi-swarm:latest
из Docker Hub. Она запустит как Swarm Master, так и Swarm агента в контейнере.Чтобы проверить все ли работает как надо, мы можем подключиться к только что созданному Swarm Master'у с используя следующую команду. Она получает все переменные среды необходимые клиентскому Docker'у для связи со Swarm.
$ eval $(./docker-machine env --swarm pi1)
$ docker info
Containers: 2
Strategy: spread
Filters: affinity, health, constraint, port, dependency
Nodes: 1
pi1: 192.168.1.202:2376
L Containers: 2
L Reserved CPUs: 0 / 4
L Reserved Memory: 0 B / 971.3 MiB
Мы успешно настроили одинокий менеджер Swarm. Чтобы ему не было одиноко, давайте запустим еще малиок.
Создайте агентов Swarm
Для оставшихся Raspberry Pi нам тоже нужно создать соединения Docker Machine с тем же идентификатором кластера. В этот раз мы запустим docker-machine без опции
--swarm-master
чтобы просто запустить контейнер агента Swarm на каждой из малин.$ ./docker-machine create -d hypriot --swarm --swarm-discovery token://$TOKEN --hypriot-ip-address 192.168.1.102 pi2
$ ./docker-machine create -d hypriot --swarm --swarm-discovery token://$TOKEN --hypriot-ip-address 192.168.1.103 pi3
Давайте посмотрим на что теперь похож наш Swarm
$ docker info
Containers: 4
Strategy: spread
Filters: affinity, health, constraint, port, dependency
Nodes: 3
pi1: 192.168.1.101:2376
L Containers: 2
L Reserved CPUs: 0 / 4
L Reserved Memory: 0 B / 971.3 MiB
pi2: 192.168.1.102:2376
L Containers: 1
L Reserved CPUs: 0 / 4
L Reserved Memory: 0 B / 971.3 MiB
pi3: 192.168.1.103:2376
L Containers: 1
L Reserved CPUs: 0 / 4
L Reserved Memory: 0 B / 971.3 MiB
Мы можем вывести все контейнеры во всем swarm'е обычной командой
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
5effaa7de4a3 hypriot/rpi-swarm:latest "/swarm join --addr 2 minutes ago Up About a minute 2375/tcp pi3/swarm-agent
6b73003b7246 hypriot/rpi-swarm:latest "/swarm join --addr 4 minutes ago Up 3 minutes 2375/tcp pi2/swarm-agent
5e00fbf7b9f6 hypriot/rpi-swarm:latest "/swarm join --addr 7 minutes ago Up 7 minutes 2375/tcp pi1/swarm-agent
02c905ec25a0 hypriot/rpi-swarm:latest "/swarm manage --tls 7 minutes ago Up 7 minutes 2375/tcp, 192.168.1.101:3376->3376/tcp pi1/swarm-agent-master
После настройки Docker Swarm вы таперь можете использовать обычные команды Docker чарез порт 3376. За более подробной информацией обратитесь к официальной документации по Docker Swarm.
Для корретной связи со Swarm Master'ом, прежде чем использовать клиент Docker не забудьте настроить окружение
$ eval $(docker-machine env --swarm pi1)
Теперь вы можете удаленно управлять свормом на Raspberry Pi с вашего мака. Видите, это было совсем не трудно!
[...]
Комментарии (8)
crezd
14.07.2015 12:05+1А какое практическое применение этой архитектуры?
BanzaiTokyo
14.07.2015 12:41Сложно сказать. Никиких бенчмарков я не видел, даже признаюсь не пробовал воспроизвести эксперимент — под руками нет трех Raspberry Pi.
За себя могу сказать, что мне бы было интересно поэкспериментировать с Docker Swarm на «настоящих», не виртуальных компьютерах.
zodiak
14.07.2015 19:53Я чувствую что статья крутая, в метре от меня лежит 1 RPi2 и я бы чисто ради интереса попробовал бы все то же самое, но не хватает сил все написанное осмыслить. Не хватает промежуточной статьи «А давайте запустим софт XXX на RPi через Docker».
Ну и картинка объясняющая что (Docker, Swarm) за что (контейнер, кластер) отвечает была бы в тему.BanzaiTokyo
14.07.2015 20:01Совершенно резонные замечания! Этой информации действительно не хватает. Но было бы сложно в одной статье все это собрать вместе (еще раз обращю внимание на то, что я сам лишь сделал перевод). Так что к сожалению, придется про Docker и про Swarm читать отдельно. Благо информации достаточно, даже здесь на хабре.
morgen2009
14.07.2015 11:23+13Что такое Docker Swarm? Что такое Docker? Что обозначает [...] в конце? Честно, спасибо за работу, но совсем непонятно, сразу вышел и пошел читать на внешних ресурсах
BanzaiTokyo Автор
14.07.2015 12:44+1Мне как переводчику сложно было бы дописывать статью. А [...] в конце, как вы уже поняли, скрывало то, что относилось конкретно к странице оригинала и читателям хабра было бы вряд ли интересно. Я рад что вы прочитали оригинал, если увидите какие-то неточности в переводе, то поделитесь.
crezd
14.07.2015 12:05+1А какое практическое применение этой архитектуры?
BanzaiTokyo Автор
14.07.2015 12:41Сложно сказать. Никиких бенчмарков я не видел, даже признаюсь не пробовал воспроизвести эксперимент — под руками нет трех Raspberry Pi.
За себя могу сказать, что мне бы было интересно поэкспериментировать с Docker Swarm на «настоящих», не виртуальных компьютерах.
zodiak
14.07.2015 19:53Я чувствую что статья крутая, в метре от меня лежит 1 RPi2 и я бы чисто ради интереса попробовал бы все то же самое, но не хватает сил все написанное осмыслить. Не хватает промежуточной статьи «А давайте запустим софт XXX на RPi через Docker».
Ну и картинка объясняющая что (Docker, Swarm) за что (контейнер, кластер) отвечает была бы в тему.BanzaiTokyo Автор
14.07.2015 20:01Совершенно резонные замечания! Этой информации действительно не хватает. Но было бы сложно в одной статье все это собрать вместе (еще раз обращю внимание на то, что я сам лишь сделал перевод). Так что к сожалению, придется про Docker и про Swarm читать отдельно. Благо информации достаточно, даже здесь на хабре.
BanzaiTokyo Автор
04.08.2015 01:24я наконец запустил на своих двух RPi docker-swarm кластер. Спасибо Стефану, сильно помог.
morgen2009
Что такое Docker Swarm? Что такое Docker? Что обозначает [...] в конце? Честно, спасибо за работу, но совсем непонятно, сразу вышел и пошел читать на внешних ресурсах
BanzaiTokyo
Мне как переводчику сложно было бы дописывать статью. А [...] в конце, как вы уже поняли, скрывало то, что относилось конкретно к странице оригинала и читателям хабра было бы вряд ли интересно. Я рад что вы прочитали оригинал, если увидите какие-то неточности в переводе, то поделитесь.