Como posso reescrever o seguinte comando com ProxyCommand
?
ssh -l username1 -t jumphost1 \
ssh -l username2 -t jumphost2 \
ssh -l username3 -t jumphost3 \
ssh -l username4 server
Isso não funciona
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
Estou ciente de seu uso com nc
, mas estou procurando uma maneira de usá-lo com mais de 3 saltos e também use essa opção com scp
. Eu verifiquei a ssh_config
página de manual, mas as informações são bastante escassas, pelo menos para mim.
EDITAR
Tentei usar ProxyCommand
aninhado em outro, ProxyCommand
conforme sugerido abaixo, mas sempre recebo algo nas seguintes linhas
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.
Felizmente, desde 7.3
-J
ou ProxyJump
serve ao meu propósito - embora eu ainda precise resolver a configuração das minhas chaves.
ssh -q -J user1@jumphost1,user2@jumphost2,user3@jumphost3 user@server