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@rocky~]$ /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): Password Enter same passphrase again: 再度同じPassword 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:/s3sLJJXH+7Ul01UDQplwwd/PkzQ6fqn7OmEWCen/6g huong@rocky The key's randomart image is: +---[RSA 3072]----+ | .o=oo.+| | o.+ooo| | ..o.o| | o= | | S o +oo| | . o.B.o+| | ....oo+o+| | o.o= =o+o| | o.oE=Xoo| +----[SHA256]-----+ |
1 |
$ cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys |
1 |
$ chmod 600 ~/.ssh/authorized_keys |
Winscpなどを利用し、秘密鍵 (~/.ssh/id_rsa) を Windows の適当な場所に保存する。
Winscpを起動する
Host name : サーバーのIPアドレス
Port number : SSHポート
User name : サーバーのログインユーザー
Password : 同上ユーザーのパスワード
を入力し、「Save」
Site name : 任意の名前
「OK」クリック
data:image/s3,"s3://crabby-images/7e5be/7e5bebd05ba5ef69abf285c0e686ef2e831e469d" alt=""
該当サーバーを確認後、「Login」クリック
data:image/s3,"s3://crabby-images/f6577/f65776c5a460b46a91891723733571ee62c27b5d" alt=""
下記画面が出れば「Update」クリック
data:image/s3,"s3://crabby-images/45aae/45aae408a4b62d2263eadaa37ac11acfecc701eb" alt=""
Passwordの欄にはログインユーザーのパスワード
data:image/s3,"s3://crabby-images/172a4/172a41c5061a117f0d09bdc29748bb221d0c1e0a" alt=""
接続されると、右欄サーバー側、左欄PC(Windows)側になる。
サーバー側の/home/huong/.ssh 配下にある「id.rsa」を左欄Windowsにドラック&ドロップして保存する
data:image/s3,"s3://crabby-images/79b6f/79b6fb1d40779f0e72f76d75e3567e11cfa9c02b" alt=""
SSH 設定ファイルの編集
パスワード認証をできないようにするため、 SSH 設定ファイルを編集する。
今度は一般ユーザではなく、 su - で rootになり行う。
1 2 3 4 5 6 7 |
$ su - Password: # vi /etc/ssh/sshd_config # 71行目 : パスワード認証不可に変更 PasswordAuthentication no # systemctl restart sshd |
Tera Termでの接続方法
Tera Termを起動し、「File」メニュー「New connection」
data:image/s3,"s3://crabby-images/794d6/794d677442e52df2c8ff89337a3c88bbbc280a50" alt=""
Host : サーバーのIPアドレス
TCP port : SSHポート番号
data:image/s3,"s3://crabby-images/de764/de7640adc52d9f05553c95bfff004f3c46eceb79" alt=""
次のセキュリティー警告が出た場合「Replace....」にチェックを入れ「Continue」
data:image/s3,"s3://crabby-images/b372f/b372fe3aaeb89585821715f0c405a1329fc73212" alt=""
User name : ログインユーザー名
Password :公開鍵、秘密鍵ペアの作成で指定したパスワード
「Use RSA/DSA....」にチェックを入れ、「Private key file」の欄には先ほどwindowsに保存した「id_rsa」を指定する
data:image/s3,"s3://crabby-images/19408/19408df3c40b322919a65587d3ec16a394162201" alt=""
PuTTYgen を使った秘密鍵の作成
Winscpを起動し「Tools」からRun Puttygen を起動する
該当サーバーを選択
Loadをクリック
data:image/s3,"s3://crabby-images/87e6f/87e6f64551059c70129fc3ad8c195958098e8d1b" alt=""
[ ファイルを開くダイアログ ] が開くのでファイルの種類を [ All Files (*.*) ] に変更して Linux サーバから転送した秘密鍵 id_rsa を読み込みます。
パスワードは上記「公開鍵、秘密鍵ペアの作成」で設定したパスワード
data:image/s3,"s3://crabby-images/963e9/963e9b593fd6dace8ed936afa1ec199142d2b4d5" alt=""
「Sve private key」をクリック
data:image/s3,"s3://crabby-images/7f9fb/7f9fb3263ad871ce2d92821cce9f51016ae9f857" alt=""
Private key file をwindowsに保存する、ファイル名は「id_rsa.ppk」とする
該当サーバーを選択し、「Edit」クリック
「Advanced」をクリック
「Authentication」を選択し、「Private key file」の欄にはwindows保存した「id_rsa.ppk」ファイルを指定する
data:image/s3,"s3://crabby-images/b24a3/b24a393fc34a88c75235d6a1b2929c945a7a67da" alt=""
「Save」をクリック
「Login」をクリック
data:image/s3,"s3://crabby-images/71cc0/71cc08b6ea0292b2713090014b6074fd1fef9625" alt=""
パスワードは上記「公開鍵、秘密鍵ペアの作成」で設定したパスワード
data:image/s3,"s3://crabby-images/79f90/79f906d19bfe8c1a5dd876f2db9631f55a06b4a3" alt=""
Tera Termで接続する場合は以下のように
「Use RSA/DSA/ECDSA/...」の欄にはwindowsに保存した「id_rsa.ppk」を指定する