Это сайт — моя персональная записная книжка. Интересна мне, по большей части, история, своя жизнь и немного программирование.

Сила .ssh/config

Извечная задача получить доступ к одной машине через другую чаще всего решается при помощи SSH-туннелей — удобно, пока не приходится получать доступ к группе машин. Недостаток традиционного решения — не всегда удаётся придумать удачное правило выбора портов, чтобы не запутаться как мы должны соединяться, чтобы попасть на нужную машину.

SSH-туннель (12.37КиБ)
Пример конфигурационного файла для получения доступа к группе машин

К счастью, есть решение лучше, которое позволяет соединяться через SSH наиболее естественным способом — как будто у нас есть прямой доступ.

Тут нам пригодится файл ~/.ssh/config, служащий для конфигурирования SSH-соединений, я обычно туда вписываю символические имена вместо айпи-адресов, логины и прочую мишуру. Но его возможности несколько шире.

Например на картинке выше у меня конфигурация, которая позволяет к любому айпи-адресу, который начинается с 172.17.0 через машину 172.17.1.131. Вся магия заключается в директиве ProxyCommand — в ней указано, что надо залогиниться на 172.17.1.131 и там запустить команду nc, которая откроет соединение на нужный нам адрес (он будет подставлен вместо «%h»).

Таким образом получается соединение, весь трафик которого без изменений попадает на нужный нам адрес, а уже в этом соединении мы выполняем обычный логин на нужную нам машину. Все аутентификации у меня, естественно, сделаны через сертификаты.

4 комментария
hshhhhh.name 2017

Можно лучше и создать хост для прокси :)

<code>
Host _proxy
HostName proxy.address.com
IdentityFile ~/.ssh/keys/proxy.key
User proxy_user

Host _destination
ProxyCommand ssh _proxy -W %h:%p
HostName destination.address.com
IdentityFile ~/.ssh/keys/destination.key
User destination_user
</code>

Потом можно писать
ssh _destination

Евгений Степанищев (bolknote.ru) 2017

Комментарий для hshhhhh.name:

Не вижу чем этот вариант лучше. Вроде как многословнее гораздо.

hshhhhh.name 2017

Ну так можно использовать разные ключи для прокси и не указывать их как параметры строки
Так можно менять параметры прокси в одном месте и это удобно если прокси использует больше чем в одном месте
Да и строка подключения к прокси «ProxyCommand ssh _proxy -W %h:%p» выглядит намного приятнее :)

Евгений Степанищев (bolknote.ru) 2017

Комментарий для hshhhhh.name:

Понятно — наглядность. Ну, у меня сертификат один и хост никакой не прокси, в другие подсети в него не выйдешь. :) А вот что можно обойтись без nc — это действительно хорошо!