Pensé que ssh_exchange_identification: Connection closed by remote host
es causado por /etc/hosts.allow
y / o /etc/hosts.deny
, pero la única entrada de permitir es ALL:ALL
y negar está vacío.
En mi Google Cloud VM he agregado:
ALL:ALL
a\etc\hosts.allow
y\etc\hosts.deny
está vacíaUna configuración de regla de firewall para Google Cloud VM para permitir tcp: 2222
GatewayPorts clientspecified
a/etc/ssh/sshd_config
Desde el destino (la computadora a la que quiero acceder) a mi Google Cloud VM :
ssh -R 0.0.0.0:2222:localhost:22 -i google_compute_engine -o UserKnownHostsFile=/dev/null -o CheckHostIP=no -o StrictHostKeyChecking=no <username>@<google vm ip>
Después de eso Netstat -plant 2222
produce:
tcp 0 0 0.0.0.0:2222 0.0.0.0:* LISTEN 2700/0
Dentro de Google Cloud VM :
ssh -p 2222 -i google_compute_engine localhost -v
OpenSSH_6.6.1, OpenSSL 1.0.1f 6 Jan 2014
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to localhost [127.0.0.1] port 2222.
debug1: Connection established.
debug1: identity file google_compute_engine type -1
debug1: identity file google_compute_engine-cert type -1
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_6.6.1p1 Ubuntu-2ubuntu2.3
ssh_exchange_identification: Connection closed by remote host
Si elimino -p 2222, el ssh
comando se conecta localmente.
Tenga en cuenta que puede ver este comportamiento exacto en muchas circunstancias. Apagué sshd en la máquina de destino y aún recibí el mismo error. Verifique los registros de su firewall y verifique que la solicitud llegue a la máquina de destino.
—
JosephK