Коллеги, добрый день. Кто-нибудь настраивал ssh для ci? Помогите разобраться. Есть два

сервера - gitlab runner (srv1) и сервер на который нужно развернуть приложение (srv2).
При обычной настройке ssh мне нужно сгенерировать ключи на srv2, передать открытый ключ на srv1 и можно подключаться.
А вот при использовании runner c docker никак не могу понять логику. На оф.сайте написаны следующие шаги:
1) Сгенерировать ключи без passphrase
2) Создать CI/CD переменную с закрытым ключом
3) Создать в gitlab-ci.yml секцию before_script:
before_script:
- 'command -v ssh-agent >/dev/null || ( apt-get update -y && apt-get install openssh-client -y )'
- eval $(ssh-agent -s)
- echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
- mkdir -p ~/.ssh
- chmod 700 ~/.ssh
4) Подтвердить ключи
5) Добавить публичный ключ к сервисам, к которым нужен доступ. Если это репо gitlab, то добавить ключ нужно в deploy key.

Что непонятно:
1) Ключи генерируются на gitlab runner (srv1), верно? А в before_script созданный на srv1 закрытый ключ копируется в docker контейнер в котором работает runner?
2) Допустим нужно скопировать docker-compose на srv2. Скрипт будет такой:
script:
- scp -r ./docker-compose.yml root@${DEPLOYMENT_SERVER_IP}:~/
Но как в этом случае должна сработать авторизация? Ведь ничего не передавалось на srv2. Получается у меня на srv1 в runner контейнере есть закрытый ключ от srv1 и открытый ключ в deploy key, но никакой связи с srv2 нет.

2 ответов

8 просмотров

Настраивал. Из твоего описания ничего не понятно. Но если совсем кратко - на удаленном сервере есть публичная часть в ~/.ssh/authorized_keys

делай, как делал. на целевом сервере должен быть открытая часть ключа, за раннере - закрытая. самый просто способ её туда доставить - переменные окружения

Похожие вопросы

Обсуждают сегодня

Так а кто может спарсить всех участников чата? Идишники
Magic
18
да пофиг на капчу зашел в чат и молчишь при этом ты нонейм? пошел вон
Magic
17
Как удалить health check в Consul? Казалось бы, это должно быть не сложно, но я не могу найти в документации ничего про это, только про добавление service с health check "в н...
Roman
2
Привет, кто может сделать юзербота с апи? Задачи: - создавать группы - создавать каналы - задавать для созданных каналов аватарку или эмоджи, имя группы - добавлять в группы...
Lencore
13
Privet! Mozhet jesti ideji - nemogu sdelatj upload backup s filestore cerez WEB. Fail okolo 450mb, eto mozhet bitj prichinoi? Nemogu ponjatj..kak zagruzitj backup... Poluchaju...
Matiss 🤘 Black Oak IT 🌳 Batumi 🌴 Latvija
5
Нужно магазин с тильды на опен кат перенести Есть кто умеет? В лс
Magic
8
Всем доброго вечера! Хочу поделиться своим злоключением с человеком, который, как оказалось сюда тоже скидывал свое резюме. Жаль, что я вашу группу не нашел раньше… человек ки...
Роман Ахмедзянов
4
А кто знает в тейлоре до сих пор есть конфликты слагов или поправили уже?
Black Cat
5
Я колись ставив гуглу антиспам 3.0, може і норм, але мені не дуже зайшло. Теж думав тиждень, що його і куди. Зупинився на трех варіантах відразу всі три і включив 1. Перевір...
𝓔𝓾𝓰𝓮𝓷𝓮𝓥 J
2
Я хочу запустить свой проект в тг. Что-то между пирамидой и майнилкой. Еще подобного ничего не было. Уникальная идея. Нужен именно не бот, а приложение. С ввод, выводом тон...
Павел А.
6
Карта сайта