Як я можу переписати наступну команду ProxyCommand
?
ssh -l username1 -t jumphost1 \
ssh -l username2 -t jumphost2 \
ssh -l username3 -t jumphost3 \
ssh -l username4 server
Це не працює
ssh -o ProxyCommand="\
ssh -l username1 -t jumphost1 \
ssh -l username2 -t jumphost2 \
ssh -l username3 -t jumphost3" \
-l username4 server
username1@jumphost1's password:
Pseudo-terminal will not be allocated because stdin is not a terminal.
Permission denied, please try again.
Permission denied, please try again.
Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password).
ssh_exchange_identification: Connection closed by remote host
Я знаю про його використання nc
, але шукаю спосіб використовувати його з 3+ хмелями, а також використовую цю опцію за допомогою scp
. Я перевірив ssh_config
сторінку man, але інформація є досить мізерною, принаймні для мене.
EDIT
Я спробував використовувати ProxyCommand
вкладені в іншому, ProxyCommand
як запропоновано нижче, але я завжди отримую щось у наступних рядках
debug3: ssh_init_stdio_forwarding: 192.17.2.2:2222
debug1: channel_connect_stdio_fwd 192.17.2.2:2222
debug1: channel 0: new [stdio-forward]
debug2: fd 4 setting O_NONBLOCK
debug2: fd 5 setting O_NONBLOCK
debug1: getpeername failed: Bad file descriptor
debug3: send packet: type 90
debug2: fd 3 setting TCP_NODELAY
debug3: ssh_packet_set_tos: set IP_TOS 0x10
debug1: Requesting no-more-sessions@openssh.com
debug3: send packet: type 80
debug1: Entering interactive session.
На щастя, оскільки 7.3
-J
або ProxyJump
служить моєму призначенню - хоча мені все одно доведеться працювати над налаштуванням своїх ключів.
ssh -q -J user1@jumphost1,user2@jumphost2,user3@jumphost3 user@server