ローカルネットワークではSSH接続ができません

ローカルネットワークではSSH接続ができません

今日、私はとても奇妙なことに気づきました。

ローカル ネットワークにサーバー (Ubuntu Server 12.04.4 LTS を実行) があり、その SSH ポートはインターネット経由でアクセスできます ( を使用して接続できますssh my.internet.ip.address)。

しかし、今日になって初めて、ローカル ネットワークでは接続できない (ssh its.local.ip.addressエラーなしで失敗する) ことに気付きました。

/etc/hosts.denyで自分のコンピューターを明示的に確認して追加しました/etc/hosts.allowが、何も変わりませんでした。もちろん、ssh とサーバー全体の再起動も試しました。利用できる新しい更新はありません。

ローカル接続に失敗しました:

myself@my-desktop ~ $ ssh -v its.local.ip.address
OpenSSH_6.2p2 Ubuntu-6ubuntu0.4, OpenSSL 1.0.1e 11 Feb 2013
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to its.local.ip.address [its.local.ip.address] port 22.
debug1: Connection established.
debug1: identity file /home/myself/.ssh/id_rsa type -1
debug1: identity file /home/myself/.ssh/id_rsa-cert type -1
debug1: identity file /home/myself/.ssh/id_dsa type -1
debug1: identity file /home/myself/.ssh/id_dsa-cert type -1
debug1: identity file /home/myself/.ssh/id_ecdsa type -1
debug1: identity file /home/myself/.ssh/id_ecdsa-cert type -1
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_6.2p2 Ubuntu-6ubuntu0.4
debug1: Remote protocol version 2.0, remote software version OpenSSH_5.9p1 Debian-5ubuntu1.4
debug1: match: OpenSSH_5.9p1 Debian-5ubuntu1.4 pat OpenSSH_5*
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr hmac-md5 none
debug1: kex: client->server aes128-ctr hmac-md5 none
debug1: sending SSH2_MSG_KEX_ECDH_INIT
debug1: expecting SSH2_MSG_KEX_ECDH_REPLY
Connection closed by its.local.ip.address
myself@my-desktop ~ $ 

ただし、リモート接続は機能します。

myself@my-desktop ~ $ ssh -v my.internet.ip.address
OpenSSH_6.2p2 Ubuntu-6ubuntu0.4, OpenSSL 1.0.1e 11 Feb 2013
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to my.internet.ip.address [my.internet.ip.address] port 22.
debug1: Connection established.
debug1: identity file /home/myself/.ssh/id_rsa type -1
debug1: identity file /home/myself/.ssh/id_rsa-cert type -1
debug1: identity file /home/myself/.ssh/id_dsa type -1
debug1: identity file /home/myself/.ssh/id_dsa-cert type -1
debug1: identity file /home/myself/.ssh/id_ecdsa type -1
debug1: identity file /home/myself/.ssh/id_ecdsa-cert type -1
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_6.2p2 Ubuntu-6ubuntu0.4
debug1: Remote protocol version 2.0, remote software version OpenSSH_5.9p1 Debian-5ubuntu1.4
debug1: match: OpenSSH_5.9p1 Debian-5ubuntu1.4 pat OpenSSH_5*
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr hmac-md5 none
debug1: kex: client->server aes128-ctr hmac-md5 none
debug1: sending SSH2_MSG_KEX_ECDH_INIT
debug1: expecting SSH2_MSG_KEX_ECDH_REPLY
debug1: Server host key: ECDSA [... hidden here ...]
debug1: Host 'my.internet.ip.address' is known and matches the ECDSA host key.
debug1: Found key in /home/myself/.ssh/known_hosts:4
debug1: ssh_ecdsa_verify: signature correct
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug1: SSH2_MSG_NEWKEYS received
debug1: Roaming not allowed by server
debug1: SSH2_MSG_SERVICE_REQUEST sent
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug1: Authentications that can continue: password
debug1: Next authentication method: password
[email protected]'s password: 
[ ... everything works just fine ... ]

この問題の原因は何でしょうか? そしてもっと重要なのは、どうすれば解決できるのでしょうか?

注: 詳細度 ( ssh -vvv) を上げると、両方の出力が逸脱するポイントでは何も追加表示されません。

答え1

サーバーは接続を切断することを決定しているため、サーバー側から問題をデバッグする必要があります。サーバー上で「root」アクセス権を持っている場合は、sshd対話的に実行できます。

/path/to/sshd -ddd -p 42

これにより、ポート 42 (別の番号を指定することもできます) で listen のコピーがsshdデバッグ モードで起動されます。フォアグラウンドで実行され、単一の接続を受け入れ、デバッグ情報を端末に出力します。

次にクライアントに接続します。

ssh -v -p 42 its.local.ip.address

運が良ければ、サーバー側のデバッグ メッセージにセッションがドロップされる理由が示されるはずです。

答え2

両方のキャプチャでクライアント マシンは同じであると想定しています (プロンプトは異なりますが)。TCP 接続を許可しているため、おそらくリバース DNS や sshd 構成の拒否ポリシーに関連していると思われます。

サーバー側で DNS をオフにして (sshd_config で UseDNS=no)、sshd を再起動してみてください (kill -1 で十分です)

答え3

このバグは複数のユーザーに影響を与えていると報告されています。

ローカルの場合は、ssh -X を実行して x 転送を無効にしてください。

また、最大転送単位[MTU]をssh_serverのMTUに合わせて調整する必要がある場合もあります。

** ローカルでそれが機能しない場合は、次を試してください:

 myself@my-desktop ~ $ ssh -v my.internet.ip.address

ネットワークから出て、また戻ってくることができれば...

サーバー構成エラーの可能性があります。sshd_config で「許可されたユーザー」と known_host が保存される場所を確認し、ユーザー「myself」の local.ip.address バージョンを追加します。

sshdのコピーが役に立つかもしれない

関連情報