RSA 公開鍵暗号方式を用いた認証によるSSH接続
公開鍵、秘密鍵ペアの作成
OpenSSH 使って Linux サーバに接続するユーザの公開鍵と秘密鍵のペアを作成します。
鍵ペアの作成は ssh-keygen をを使います。
今回はSSH プロトコル Version 2 で利用する RSA 暗号を利用した鍵セットを作成します。
公開鍵と秘密鍵のペアの作成はリモートログインするユーザ権限(huong)で実行します。
作成先・ファイル名を指定しなければ、 /home/huong/.ssh/ に id_rsa, id_rsa.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 - huong huong@debian:~$ /usr/bin/ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/home/huong/.ssh/id_rsa): 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_rsa Your public key has been saved in /home/huong/.ssh/id_rsa.pub The key fingerprint is: SHA256:/lhLZaXfeCJOzm0TA4wPqQtUgqKn9+W01HRustCcSWs huong@Lepard The key's randomart image is: +---[RSA 3072]----+ | . | | . . . . | | . . o + . | |. . . o = oo | | o . *SB o+. | |. . *.E oo..oo | | . . = =.=o o +oo| | . o o= * ooo | | . o +... | +----[SHA256]-----+ |
1 2 3 |
$ chmod 700 ~/.ssh $ cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys $ chmod 600 ~/.ssh/authorized_keys |
Winscpなどを利用し、秘密鍵 (~/.ssh/id_rsa) を Windows の適当な場所に保存する。
Winscpを起動する
Host name : サーバーのIPアドレス
Port number : SSHポート
User name : サーバーのログインユーザー
Password : 同上ユーザーのパスワード
を入力し、「Save」
data:image/s3,"s3://crabby-images/f8d72/f8d72b3e18b6158a2239d38ba0f29c73ec20b4be" alt=""
Site name : 任意の名前
data:image/s3,"s3://crabby-images/9e1b1/9e1b17decfe191fb4534b57aec967e94190445b9" alt=""
該当サーバーを確認後、「Login」クリック
data:image/s3,"s3://crabby-images/b7480/b7480b4906178b2ea640c25d7011986702dcd905" alt=""
下記画面が出れば「Update」クリック
data:image/s3,"s3://crabby-images/bb622/bb62284f395088046d8289d42b9e0d9d2533c6b8" alt=""
Passwordの欄にはログインユーザーのパスワード
data:image/s3,"s3://crabby-images/ad222/ad222975e52d176ed20cd066d53372c7d2e7262e" alt=""
接続されると、左欄サーバー側、右欄PC(Windows)側になる。
サーバー側の/home/huong/.ssh 配下にある「id.rsa」をWindowsにドラック&ドロップして保存する
data:image/s3,"s3://crabby-images/54fbc/54fbc8feaa1850a1d11ab087cd5555f0e0ad1ab1" alt=""
SSH 設定ファイルの編集
パスワード認証をできないようにするため、 SSH 設定ファイルを編集する。
今度は一般ユーザではなく、 su - で rootになり行う。
1 2 3 4 5 6 7 8 9 |
$ su - Password: # vi /etc/ssh/sshd_config # 58行目あたり #PasswordAuthentication yes ← 行頭の#削除してコメント解除し、下記に変更 PasswordAuthentication no # systemctl restart sshd |
Tera Termでの接続方法
Tera Termを起動し、「File」メニュー「New connection」
data:image/s3,"s3://crabby-images/22d71/22d7140ae5a1a2e85ef933eb7a97d6aee5101398" alt=""
Host : サーバーのIPアドレス
TCP port : SSHポート番号
data:image/s3,"s3://crabby-images/46e31/46e31978bad895dacbf7b68e7d7b8686becb4a3c" alt=""
次のセキュリティー警告が出た場合「Replace....」にチェックを入れ「Continue」
data:image/s3,"s3://crabby-images/e8396/e8396f9dbc42b6376a6af7859e5bf51ee3ba4e53" alt=""
User name : ログインユーザー名
Password :公開鍵、秘密鍵ペアの作成で指定したパスワード
「Use RSA/DSA....」にチェックを入れ、「Private key file」の欄には先ほどwindowsに保存した「id_rsa」を指定する
data:image/s3,"s3://crabby-images/c121b/c121bd37fc247900b4e09eb28818ba2e43b75b7f" alt=""
PuTTYgen を使った秘密鍵の作成
Winscpを起動し「Tools」からRun Puttygen を起動する
該当サーバーを選択
data:image/s3,"s3://crabby-images/c1996/c199658453070843e50a19b8e229c7e8344d7bcf" alt=""
Loadをクリック
data:image/s3,"s3://crabby-images/057f5/057f525aea132d7d790d3cf96414427406811fb1" alt=""
[ ファイルを開くダイアログ ] が開くのでファイルの種類を [ All Files (*.*) ] に変更して Linux サーバから転送した秘密鍵 id_rsa を読み込みます。
data:image/s3,"s3://crabby-images/76e6e/76e6e2a6bb12cab4778cd62246683ae51ac98780" alt=""
パスワードは上記「公開鍵、秘密鍵ペアの作成」で設定したパスワード
data:image/s3,"s3://crabby-images/92a04/92a04f8d5643f4463e12892d33c193b3ab965aff" alt=""
data:image/s3,"s3://crabby-images/b320d/b320dabab2b6720a4ff7e21fa67f28aebb3cec96" alt=""
data:image/s3,"s3://crabby-images/1867d/1867d51b2228d104b53a3ca1bf05391a0bf10fcc" alt=""
Private key file をwindowsに保存する、ファイル名は「id_rsa.ppk」とする
data:image/s3,"s3://crabby-images/f8935/f89352555d340f96ee692d5ec70b1409951c4716" alt=""
該当サーバーを選択し、「Edit」クリック
data:image/s3,"s3://crabby-images/f2df5/f2df5eab650fe02313efeab9f5cb84f2d07e5d59" alt=""
「Advanced」をクリック
data:image/s3,"s3://crabby-images/811fb/811fb312ef55cd8c50811aa5665da2dbea1ac3e4" alt=""
「Authentication」を選択し、「Private key file」の欄にはwindows保存した「id_rsa.ppk」ファイルを指定する
data:image/s3,"s3://crabby-images/c26b4/c26b477498a4504d6dfa4eb841be72016702f795" alt=""
「Save」をクリック
data:image/s3,"s3://crabby-images/4d9d3/4d9d3181cdfbf943761685f83a1afd55e17609c9" alt=""
「Login」をクリック
data:image/s3,"s3://crabby-images/c0617/c06176e3e989316de0cf0e44bc943e5cb293e477" alt=""
パスワードは上記「公開鍵、秘密鍵ペアの作成」で設定したパスワード
data:image/s3,"s3://crabby-images/746d0/746d071e400eebb63bb6e6971bbb995114b0c25b" alt=""
Tera Termで接続する場合は以下のように
「Use RSA/DSA/ECDSA/...」の欄にはwindowsに保存した「id_rsa.ppk」を指定する
data:image/s3,"s3://crabby-images/a59df/a59df40286523b700439fdc92b51ce980daee8cc" alt=""