Я ищу способ использовать определенные блоки CIDR для соответствия хостов в конфигурации клиента SSH (обычно ~/.ssh/config
). Например, у меня есть запись для пересылки всего трафика через бастионный хост, если IP попадает в определенный диапазон, скажем 10.1.0.0/16
:
host 10.1.*
proxycommand ssh -q bastion -W %h:%p
Это работает очень хорошо, но как насчет того, когда я добавлю некоторые диапазоны, которые точно не соответствуют точечной нотации?
# doesn't work, unfortunately
host 10.2.0.0/18
proxycommand ssh -q bastion-foo -W %h:%p
host 10.2.64.0/18
proxycommand ssh -q bastion-bar -W %h:%p
Есть ли в руководстве что-то, что я пропустил, или умный трюк с скриптингом, который позволил бы сопоставить эти диапазоны IP хоста?
host
записями. Также необходимо, чтобы каждый цитировался отдельно (ssh / Mac).host "10.2.?.*", "10.2.??.*", "!10.2.64*", "!10.2.65*", "!10.2.66*", "!10.2.67*", "!10.2.68*", "!10.2.69*", "!10.2.7*", "!10.2.8*", "!10.2.9*"
host "10.2.??.*", "10.2.10?.*", "10.2.11?.*", "10.2.12?.*", "!10.2.1?.*", "!10.2.2?.*", "!10.2.3?.*", "!10.2.4?.*", "!10.2.5?.*", "!10.2.60.*", "!10.2.61.*", "!10.2.62.*", "!10.2.63.*", "!10.2.128.*", "!10.2.129.*"
Следите за http://bugzilla.mindrot.org/show_bug.cgi?id=1169, который в конечном итоге может обеспечить механизм для этого.
источник