1
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

SSH接続するための備忘録

Last updated at Posted at 2024-11-06

はじめに

Linuxでサーバーを立てる講義があってサーバー作りたい熱が再燃してしまったので、今後のためにどうやってSSH接続のセットアップを行うのか残したいと思います。
ただLinuxの扱いに慣れていないためまだまだ間違いなどあるとは思いますが温かい目で見守っていただけると幸いですm(_ _)m

環境

  • SSHサーバー
    dynabook Satellite B65/R

    型番 PB65RNAAC27AD11
    CPU インテル® Celeron® プロセッサー 3215U
    RAM 8GB
    ストレージ 500GB(HDD)
    OS Lubuntu 24.04.1 LTS
  • SSHクライアント
    dynabook RZ/MW

    型番 W6RZMW7BAL
    CPU 13th Gen Intel(R) Core(TM) i7-1360P
    RAM 32.0GB
    ストレージ 1TB(SSD)
    OS Windows 11 Home 24H2
    クライアント Tera Term Version5.2 (Git 176aed267)
  • ネットワーク環境

    マシン IPアドレス
    サーバー 192.168.255.200/24(固定)
    クライアント 192.168.255.58/24(DHCP)

SSHサーバーとして格安でもらった色々と壊れてしまっている約10年落ちのノートパソコンを使用します。
SSHクライアントは普段大学でも使っているパソコンになります。
ネットワーク環境としては自分の部屋だけに張り巡らしたLANに接続してあります。そこから家全体のLANさらにマンション全体のLANと接続しているので二重ルーターどころではなく三重ルーターとなってしまっています。そのためいつか三重ルーターでも外部からアクセスできるようにしたいなと考えています。

ノートパソコンを24時間起動させることは火災のリスクなどもあり賛否両論があります。ご自身の責任で行うようにしてください。

手順

このノートパソコンはディスプレイを閉じてヘッドレスで使用したいため以下の呪文を詠唱します。

# systemctl mask sleep.target suspend.target hibernate.target hybrid-sleep.target
Created symlink /etc/systemd/system/sleep.target → /dev/null.
Created symlink /etc/systemd/system/suspend.target → /dev/null.
Created symlink /etc/systemd/system/hibernate.target → /dev/null.
Created symlink /etc/systemd/system/hybrid-sleep.target → /dev/null.

これによりディスプレイを閉じて使用してもスリープモードやスクリーンセーバーに移行することがなくなります。

インストールする

最初UbuntuLubuntuをインストールした段階ではsshのクライアントは入っていてもサーバーは入っていないのでOpenSSHをインストールします。
詳しくはこちらなどをご覧ください SSHについて #Linux - Qiita

# apt install openssh-server
# systemctl status ssh
○ ssh.service - OpenBSD Secure Shell server
     Loaded: loaded (/usr/lib/systemd/system/ssh.service; disabled; preset: enabled)
     Active: inactive (dead)
TriggeredBy: ● ssh.socket
       Docs: man:sshd(8)
             man:sshd_config(5)

これでOpenSSHサーバーをインストールすることができました。しかしこのままではインストールしただけで起動していないので手動でスタートしてやる必要があります。

# systemctl start ssh
# systemctl status ssh
● ssh.service - OpenBSD Secure Shell server
     Loaded: loaded (/usr/lib/systemd/system/ssh.service; disabled; preset: enabled)
     Active: active (running) since Wed 2024-11-06 17:41:59 JST; 3min 13s ago
TriggeredBy: ● ssh.socket
       Docs: man:sshd(8)
             man:sshd_config(5)
    Process: 19675 ExecStartPre=/usr/sbin/sshd -t (code=exited, status=0/SUCCESS)
   Main PID: 19676 (sshd)
      Tasks: 1 (limit: 9322)
     Memory: 1.2M (peak: 1.4M)
        CPU: 32ms
     CGroup: /system.slice/ssh.service
             └─19676 "sshd: /usr/sbin/sshd -D [listener] 0 of 10-100 startups"

11月 06 17:41:59 dynabook systemd[1]: Starting ssh.service - OpenBSD Secure Shell server...
11月 06 17:41:59 dynabook sshd[19676]: Server listening on :: port 22.
11月 06 17:41:59 dynabook systemd[1]: Started ssh.service - OpenBSD Secure Shell server.
# ssh -V
OpenSSH_9.6p1 Ubuntu-3ubuntu13.5, OpenSSL 3.0.13 30 Jan 2024

Active: active (running)となり緑色の丸が表示されていれば無事成功となります。
そして最後にOSを起動した際に自動でサーバーも起動できるようにします

# systemctl enable ssh

これでインストール自体は完了です。

セキュリティを高める

OpenSSH自体のインストールは前述の手順で完了となります。しかしこのままではユーザー名とパスワードが判ればアクセスできてしまうなどのセキュリティリスクがあります。以下の事も最低限行うようにします。

/etc/ssh/sshd_config
- #port 22
- #PermitRootLogin prohibit-password
- #PubkeyAuthentication yes
- #PermitEmptyPasswords no
+ port 10022
+ PermitRootLogin no
+ PubkeyAuthentication yes
+ PermitEmptyPasswords no

以上のように14,33,38,58行目をそれぞれ書き換えます。
一つづつ説明すると

  • 14行目(port)
    sshする際のポートを変更する。これによってBrute Force Attackを受ける可能性が低くなることが期待されます。

  • 33行目(PermitRootLogin)
    ここではrootユーザーのログインを許可するかどうかを設定します。オプションとしての一例として以下のようなものがあります。

    yes rootユーザのログインを許可
    prohibit-password 通常のパスワード認証と、キーボードインタラクティブ認証(2要素認証など)を拒否するが、公開鍵認証とGSSAPI認証(Kerberos認証など)だけは許可される。
    no rootユーザのログインを許可しない
  • 38行目(PubkeyAuthentication)
    公開鍵認証を利用するか否かです。
    デフォルトでyesに設定されていますがここでは明示的にyesにしてあります。

  • 58行目(PermitEmptyPasswords)
    あんまり無いとは思いますがパスワードが設定されていないユーザーのログインを禁止するものです。

sshd -tと構文チェックを行い何もエラーが表示されなかったら「構文上」は問題はありません。そしたらsshの設定を再読み込みします。

# sshd -t
# systemctl restart sshd

以上で設定したことが機能しているか10022ポートでの接続ならびにrootユーザーでの認証ができるかを確かめてください。
できるようになったことを確認するのは大切ですができないようになったことを確認することも同じように大切なので…
またtipとしてsshd -Tと実行することで今現在の設定を確認することができます。

公開鍵認証

ここでは公開鍵認証についての説明は省こうと思います。ただ公開鍵認証について全く何も知識がなければ次のサイトを見てみて「こんなことをしてるんだなー」と理解してみたほうがいいかもしれません。
公開鍵認証方式とは|「分かりそう」で「分からない」でも「分かった」気になれるIT用語辞典

コマンドラインで公開鍵と秘密鍵を作成することもできますがここでは簡単のためTera Termの機能を利用したいと思います。
スクリーンショット 2024-11-06 223129.png
Tera Termでは[設定]>[SSH鍵生成]と選択することで以下のフォームが出てきます。
鍵の作成
RSAやED25519などのような暗号化方式を選ぶことができますがここではED25519を選択しました。
どうやらRSAよりED25519のほうが高速かつセキュアらしいので…
「なにそれ!詳しく知りたいよー!」って方はここも見てみると良いでしょう。
気付けばssh-keygen -t の後にrsaでなくed25519と打つことが推奨されていた | ABC DX Tech Blog

RSA暗号ではビット数を選択する必要があります。世の中的には2048ビット以上が推奨となってきているみたいです。
またパスフレーズは認証のたびに求められますが一応空欄にすることもできます。
そして[公開鍵の保存]、[秘密鍵の保存]をそれぞれクリックし覚えやすい場所に保存しましよう。(特に秘密鍵はログインのたびに使用するので…)
そして作成した公開鍵ファイルをサーバーに転送します。

(*.pub)形式の公開鍵ファイルをアップロードしてください。秘密鍵はアップロードしないようにしてください。

ファイルをTera Termにドラッグ&ドロップすることで以下のダイアログが起動します。転送先は自由ですがわかりやすい場所にしましょう。

ファイルサイズが小さいのでアップロード自体はすぐに終了すると思います。
終了したらコマンドラインの操作に戻りましょう。ここではrootユーザーではなくログインしたいユーザーで操作しましょう。

$ pwd
/home/<ユーザー名>
$ mkdir .ssh
$ chmod 700 .ssh
$ cd .ssh
$ cat /tmp/id_ed25519.pub >> authorized_keys
$ chmod 600 authorized_keys

ユーザーディレクトリ直下に.sshというディレクトリを作成します。ここには公開鍵を保存するので権限を700か600に設定します。そしたら転送したファイルの中身をそのままauthorized_keysというファイルに書き込みます。最後に同じように権限を600に設定したら完了です。

ここで一度ログアウトしてみて公開鍵認証できるかを試してみましょう。
もしできない場合は先に進まないでもう一度やり直してみましょう。

さて公開鍵認証が設定できたら公開鍵認証以外のログインを塞ぎます。

/etc/ssh/sshd_config
- #PasswordAuthentication yes
+ PasswordAuthentication no

57行目を上のように書き換えます。

# sshd -t
# systemctl restart sshd

そして呼吸をするように構文チェックと設定の再読み込みを行います。こうすることでパスワード認証ができなくなるので以降は公開鍵認証を使ってログインしなければなりません。

ファイアウォール

最後にファイアウォールを設定したいと思います。UbuntuやLubuntuにはufwという簡単なツールが入っています。

# systemctl status ufw
● ufw.service - Uncomplicated firewall
     Loaded: loaded (/usr/lib/systemd/system/ufw.service; enabled; preset: enabled)
     Active: active (exited) since Wed 2024-11-06 18:10:16 JST; 52min ago
       Docs: man:ufw(8)
   Main PID: 525 (code=exited, status=0/SUCCESS)
        CPU: 8ms

11月 06 18:10:16 dynabook systemd[1]: Starting ufw.service - Uncomplicated firewall...
11月 06 18:10:16 dynabook systemd[1]: Finished ufw.service - Uncomplicated firewall.

OS搭載機器を目の前にしてローカルのコンソールを使って設定する場合は、失敗したら元に戻せばいいので特に気にする必要はありません。
しかし、sshを使ってsshdの変更をしなければいけないケースが多々有ります。
当然記述ミスや設定値の間違いなどで、再起動後につながらなくなっていまうおそれがあります。
そんな困った状況を避けるため、sshdは再起動しても接続済みのセッションは維持してくれる親切設計になっています。
この機能を保険として、何かを変更する際にはターミナルを2つ起動して、接続済みセッションを用意しておくよう心がけましょう。
sshを使うための各設定

とのことなので以下の作業を実行する際にはもう一つウィンドウを開いておいて作業を戻せるようにしてください。

# ufw default deny
デフォルトの incoming ポリシーは 'deny' に変更しました
(適用したい内容に基づいて必ずルールを更新してください)
# ufw allow 10022
ルールを追加しました
ルールを追加しました (v6)
# ufw enable
Command may disrupt existing ssh connections. Proceed with operation (y|n)? y
ファイアウォールはアクティブかつシステムの起動時に有効化されます。

許可するポート番号を間違えないように注意してください。

ここではデフォルトポリシーとしてパケットを棄却するようにしています。
しかし10022/TCPに来るIPv4,IPv6のパケットのみ通過するようにしました。ここで開くポートは/etc/ssh/sshd_configの14行目で設定したポートと合わせるようにします。
そして最後に新しくウィンドウを開き公開鍵認証でログインできることを確かめられば成功となります。

最後に

この記事では新しく作成したLubuntuのサーバーにsshするための手順を解説しました。しかしsshの脆弱性を利用してサーバーをハッキングされてしまうこともあります。ここで説明したのは基本的なセキュリティ対策ですがスマホアプリ(Google Authenticator等)を使った2要素認証(TOTP)やIPアドレス(CIDR表記)によるアクセス制限も設定できるようです。これからはそういった対策やAdGuard Homeのインストール、三重ルーター下のNAT越えなどにも取り組んでみたいと思います。
この記事は以上となります。ご覧いただきありがとうございました。

参考文献

Linuxサーバー構築標準教科書(Ver.4.0.0)

SSHサーバーの設定 - Linux技術者認定 LinuC | LPI-Japan

1
2
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
1
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?