LoginSignup
5
3

More than 1 year has passed since last update.

TeratermでlinuxユーザーがSSH接続で認証失敗したため、いろいろ試してみた

Last updated at Posted at 2022-12-03

はじめに

TeraTeramで登録したlinuxユーザーでログイン出来ない事象が起きたため、この記事に調査した内容をまとめました。
同じ事象が起きた方は良かったら参考にしてください。

動作条件

OS CentOS7
VirtualBoxでゲストOSを作成しました。
端末 Windows 11
TeraTerm ver 4.106

ユーザー登録

以下の手順に従いユーザーホームディレクトリを/home以外でユーザー登録をしました。
https://qiita.com/gama1234/items/9dde01ea507cac003cfa

TeraTerm 秘密鍵認証でログインできない事象

TeraTermの画面でユーザー名と秘密鍵を指定した後、
誤ったパスワードを入力すると、以下のメッセージが出ますが、正しいパスワードを入れるとメッセージのポップアップは何も出ませんが、認証失敗になります。認証失敗時にログ「/var/log/secure」にエラーが出力されないため、原因は不明です。

例)誤ったパスワードを入れた場合のメッセージ
image.png

SSH接続失敗時のTeraTermの画面
image.png

linuxユーザーを何度か登録しましたが、事象発生する頻度としてはユーザーホームディレクトリが/homeのユーザーは本事象が発生しずらく、主に/home以外のユーザーで本事象が発生しやすいと感じました。

試したこと

鍵の権限と所有ユーザーを確認した

ログイン出来ないユーザーの鍵の権限を確認したが、問題なし

#.ssh配下の権限を確認した。
[root@localhost test]# ls -ltr /test/test_user1/.ssh
合計 16
-rw-------. 1 test_user1 test 1766 12月  3 09:46 test_user1.pem
-rw-------. 1 test_user1 test  414 12月  3 09:46 authorized_keys
-rw-r--r--. 1 test_user1 test  414 12月  3 23:30 id_rsa.pub
-rw-------. 1 test_user1 test 1766 12月  3 23:30 id_rsa

念のため、.sshのフォルダの所有ユーザーと権限を確認したが問題なし

[root@localhost test]# ls -tlra /test/test_user1
合計 16
-rw-r--r--. 1 test_user1 test 231  4月  1  2020 .bashrc
-rw-r--r--. 1 test_user1 test 193  4月  1  2020 .bash_profile
-rw-r--r--. 1 test_user1 test  18  4月  1  2020 .bash_logout
drwx------. 3 test_user1 test  95 12月  3 10:42 .
drwxr-xr-x. 4 root       root  42 12月  3 23:28 ..
drwx------. 2 test_user1 test  83 12月  3 23:30 .ssh
-rw-------. 1 test_user1 test  93 12月  3 23:31 .bash_history

ユーザーも問題なく登録されている

[root@localhost test]# cat /etc/passwd | grep test_user1
test_user1:x:<ユーザーID>:<グループID>::/test/test_user1:/bin/bash

パスワード認証

パスワード認証でログインを試すと問題なくログイン出来ました。
image.png
ログイン成功した。
image.png
ログは正常に出力された。

[root@localhost ~]# tail -n 2 /var/log/secure
※パスワード認証のログ
Dec  4 21:15:12 localhost sshd[1422]: pam_unix(sshd:session): session opened for user test_user1 by (uid=0)

sshdのコンフィグファイルにssh-rsaを設定

今回のケースはSSH接続出来るユーザーもあれば、出来ないユーザーもあるため、以下の設定をしても改善しない可能性はありますが、試してみました。

CentOS7で上記を試しましたが、コンフィグのエラーが出て設定出来ませんでした。

※SSHのバージョンは以下です。
OpenSSH_7.4p1, OpenSSL 1.0.2k-fips  26 Jan 2017
[root@localhost ssh]# sed -i '1s/^/PubkeyAcceptedAlgorithms=+ssh-rsa\n/' /etc/ssh/sshd_config
[root@localhost ssh]#
[root@localhost ssh]# head /etc/ssh/sshd_config
PubkeyAcceptedAlgorithms=+ssh-rsa
#       $OpenBSD: sshd_config,v 1.100 2016/08/15 12:32:04 naddy Exp $

# This is the sshd server system-wide configuration file.  See
# sshd_config(5) for more information.

sshdのサービスを再起動したらエラーが出ました。

[root@localhost ssh]# systemctl restart sshd
Job for sshd.service failed because the control process exited with error code. See "systemctl status sshd.service" and "journalctl -xe" for details.

[root@localhost ssh]# journalctl -xe
-- Unit sshd.service has begun starting up.
12月 03 11:53:35 localhost.localdomain systemd[1]: sshd.service: main process exited, code=exited, status=255/n/a
12月 03 11:53:35 localhost.localdomain sshd[1989]: /etc/ssh/sshd_config: line 1: Bad configuration option: PubkeyAcceptedAlgorithms
12月 03 11:53:35 localhost.localdomain sshd[1989]: /etc/ssh/sshd_config: terminating, 1 bad configuration options
12月 03 11:53:35 localhost.localdomain systemd[1]: Failed to start OpenSSH server daemon.

Puttyでログインを試した

SSH接続失敗しました。
サーバーのIPアドレスを入れました。
image.png
秘密鍵を指定しました。
image.png

鍵の読み込みに失敗しました
image.png

WSLでログインを試した

SSH接続が成功しました。

test@DESKTOP-0S2U0NI:~$ ssh -i test_user1.pem test_user1@192.168.40.118
Enter passphrase for key 'test_user1.pem':
Enter passphrase for key 'test_user1.pem':
test_user1@192.168.40.118's password:
Last login: Sat Dec  3 12:05:11 2022 from 192.168.40.113
[test_user1@localhost ~]$

MSYS2でログインを試した

SSH接続成功しました。
最初にOpenSSHをインストールしました

$ pacman -S openssh
resolving dependencies...
looking for conflicting packages...

Packages (4) heimdal-7.7.0-4  libcbor-0.9.0-1  libfido2-1.12.0-1  openssh-8.9p1-3

Total Download Size:   1.43 MiB
Total Installed Size:  7.93 MiB

:: Proceed with installation? [Y/n] y
:: Retrieving packages...
 libcbor-0.9.0-1-x86_64                                                                     18.0 KiB  8.49 KiB/s 00:02 [######################################################################] 100%
 libfido2-1.12.0-1-x86_64                                                                   76.7 KiB  32.3 KiB/s 00:02 [######################################################################] 100%
 heimdal-7.7.0-4-x86_64                                                                    434.7 KiB   153 KiB/s 00:03 [######################################################################] 100%
 openssh-8.9p1-3-x86_64                                                                    937.5 KiB   321 KiB/s 00:03 [######################################################################] 100%
 Total (4/4)                                                                              1466.8 KiB   439 KiB/s 00:03 [######################################################################] 100%
(4/4) checking keys in keyring                                                                                         [######################################################################] 100%
(4/4) checking package integrity                                                                                       [######################################################################] 100%
(4/4) loading package files                                                                                            [######################################################################] 100%
(4/4) checking for file conflicts                                                                                      [######################################################################] 100%
(4/4) checking available disk space                                                                                    [######################################################################] 100%
:: Processing package changes...
(1/4) installing heimdal                                                                                               [######################################################################] 100%
(2/4) installing libcbor                                                                                               [######################################################################] 100%
(3/4) installing libfido2                                                                                              [######################################################################] 100%
(4/4) installing openssh                                                                                               [######################################################################] 100%

SSH接続がうまく行きました

$ ssh -i test_user1.pem test_user1@192.168.40.118
Enter passphrase for key 'test_user1.pem':
test_user1@192.168.40.118's password:
Last login: Sat Dec  3 12:08:40 2022 from 192.168.40.113
[test_user1@localhost ~]$

WinSCPで接続を試しました

接続が成功しました。
image.png
image.png

まとめ

調査した結果、TeraTermとPuttyでSSH接続に失敗し、WSLとMSYS2の様にSSHコマンドを使用した場合はSSH接続出来たため、
上記からGUIのターミナルがSSH接続出来ない事象が起きる可能性があると理解しました。

TeraTermのパスワード認証はログイン出来たため、TeraTermで何らかの理由により、鍵の読み込みが上手く行かずに、SSH接続が実行されていないのが原因で、認証失敗がログに出力されていない可能性があると思いました。

私の周りでも、TeraTeramのターミナルだとSSH接続出来ずに、SSHコマンドだとログイン出来るという事象が起きたことがあると伺いました。原因は不明ですが、最近のディストリビューションでは、SSHするサーバ側の何らかのポリシーに、TeraTermが対応していない可能性もあるそうです

回避策として、GUIのターミナルでSSH接続が出来ない際は、SSHコマンドでSSH接続できるCUIのターミナルを使用することを検討した方が良いです。

5
3
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
3