SSH の公開鍵暗号方式設定
1.公開鍵、秘密鍵ペアの作成
OpenSSH 使って Linux サーバに接続するユーザの公開鍵と秘密鍵のペアを作成します。
鍵ペアの作成は ssh-keygen をを使います。
公開鍵と秘密鍵のペアの作成はリモートログインするユーザ権限で実行します。
作成先・ファイル名を指定しなければ、 /home/(ユーザ名)/.ssh/ に id_ed25519, id_ed25519.pub が作成される。 途中、鍵用のパスワードも入力する。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
# su – <user name> $ ssh-keygen -t ed25519 Generating public/private ed25519 key pair. Enter file in which to save the key (/home/huong/.ssh/id_ed25519): Created directory '/home/huong/.ssh'. Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /home/huong/.ssh/id_ed25519. Your public key has been saved in /home/huong/.ssh/id_ed25519.pub. The key fingerprint is: SHA256:nIJyadLBDmXJoozL8K2TGA6yXzPSV181nbT3R3+QSVE huong@localhost.localdomain The key's randomart image is: +--[ED25519 256]--+ | .o. o+E| | .+o ..+o| |o...o *o+| |+. + + . . . ++| |ooo.B . S . =| |=..*. o . . o| |++.o= . . | |o.+o + | | ... | +----[SHA256]-----+ |
1 2 3 |
$ cat ~/.ssh/id_ed25519.pub >> ~/.ssh/authorized_keys $ chmod 600 ~/.ssh/authorized_keys $ chmod 700 ~/.ssh/ |
2.秘密鍵ログイン設定
1 2 3 4 5 6 7 8 |
$ su - パスワード: # vi /etc/ssh/sshd_config ■49 行目あたり行頭の「#」を削除 変更前) #PubkeyAuthentication yes 変更後) PubkeyAuthentication yes |
SSH を再起動
1 |
# systemctl restart sshd.service |
秘密鍵をクライントPC にコピー(WinSCP使う) WinSCPの設定を行います
①WinSCPを起動し、「New Site」で次のように設定し、「Save」
Host name : サーバーのIPアドレス
Port number : SSHポート番号
User name : ユーザー名
Password : ユーザーのパスワード
data:image/s3,"s3://crabby-images/c97fd/c97fd827acf04ed1f4c3ceb9a59bd911ff7f3a48" alt=""
接続名を任意の名前でつける
data:image/s3,"s3://crabby-images/50317/50317861ad8dc1d5880940a1faef7348715d412b" alt=""
下記の画面に戻りますので「Login」
data:image/s3,"s3://crabby-images/72e5c/72e5c3931d341f85019d166f2569b6556a46c506" alt=""
下記の画面が出れば「Update」
data:image/s3,"s3://crabby-images/481b4/481b4535e5c2a46b2bee1633c05f8e3078ac164f" alt=""
下記の画面では「Pasword」にユーザーのパスワードを入力する
data:image/s3,"s3://crabby-images/28d34/28d34f89d70c287d859fc9021ffd21512fecdc92" alt=""
下記の画面になりますので /home/ユーザー/.ssh ディレクトリーにあるid_ed25519をwindows側の任意の場所にコピーする(id_ed25519を選択し、左側にドラッグ&コピー)
data:image/s3,"s3://crabby-images/3bd14/3bd14f61c0559523102c3f9ffb43e661653698bc" alt=""
3.秘密鍵でのみログインするよう変更します
1 2 3 4 5 |
# vi /etc/ssh/sshd_config ■69 行目あたり 「#PasswordAuthentication yes」の下に「PasswordAuthentication no」を追加 #PasswordAuthentication yes PasswordAuthentication no |
SSH を再起動
1 |
# systemctl restart sshd.service |
4.PuTTYgen を使った秘密鍵の作成
Winscp起動しツールからRun PuTTYgen を起動
data:image/s3,"s3://crabby-images/03486/03486f6689e639071af5b90c9249ffe12d14e98e" alt=""
Loadをクリック[ ファイルを開くダイアログ ] が開くのでファイルの種類を [ All Files (*.*) ] に変更して Linux サーバから転送した秘密鍵 id_ed25519 を読み込みます。
data:image/s3,"s3://crabby-images/9dae6/9dae613b7b828274d820f9e868a9eeceb834d281" alt=""
data:image/s3,"s3://crabby-images/42807/42807dc48cea8c1f18c9501ef7abd82b167a0d93" alt=""
サーバー側で秘密鍵を作成したときに入力したパスフレーズを入力します
data:image/s3,"s3://crabby-images/2dfde/2dfde77ea474abbba9f19d7788da8addf057d654" alt=""
以下のように表示されると [ OK ] ボタンをクリックします。
data:image/s3,"s3://crabby-images/215be/215be16ecfeee8619a2773bad01c0134881e81ab" alt=""
[ Save private key ] ボタンをクリックして秘密鍵を保存します。
data:image/s3,"s3://crabby-images/ba6da/ba6da850a2557862ae9c4be5e6a538a221e93bc2" alt=""
ここでは id_ed25519.ppk として保存します(Windowsに)。
data:image/s3,"s3://crabby-images/ee3e9/ee3e9359f8e6c874c30aa9be15cfee99f241a286" alt=""
該当サーバーを選択し、「Edit」クリック
data:image/s3,"s3://crabby-images/5eb96/5eb96463937da0728edca8e631e5b010011c5170" alt=""
「Advanced」をクリック
data:image/s3,"s3://crabby-images/98da1/98da1e4272d5b2fbcb37f66d4ada1d826d021a5e" alt=""
「Authentication」メニューを開き、「Private key file」に先ほどWindowsに保存した「id_ed25519.ppk」を指定する
data:image/s3,"s3://crabby-images/f47f8/f47f85a241c75db403f0614a864659f99b1d46c3" alt=""
「Save」をクリック
data:image/s3,"s3://crabby-images/14288/1428824aadedd2582343334c59897b8ed2f05c3d" alt=""
「Login」をクリック
data:image/s3,"s3://crabby-images/eb3ec/eb3ec9da941c7a74b37c0bb0b9f5b74f942657d1" alt=""
パスワードは上記「公開鍵、秘密鍵ペアの作成」で設定したパスワード
data:image/s3,"s3://crabby-images/71249/71249e9b33ee983c8b9ba632f71e718dbb855130" alt=""
正常に接続されると下記のように右側にサーバー側、左側にWindows側が表示される
data:image/s3,"s3://crabby-images/6a03f/6a03f31dd36a3aa0e64e20b53f73a82fb3c98d75" alt=""
Tera Termで接続する場合
「Use RSA/DSA/ECDSA/...」の欄にはwindowsに保存した「id_ed25519.ppk」を指定する
data:image/s3,"s3://crabby-images/b999b/b999b46bf6b5399958f0cd14770ff63ff1091b3c" alt=""
これでSSHサービスのセキュリティ設定は完了です。