3
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

VPS借りたらrootユーザーがパスワード認証でグローバル公開されている、さあ何から手を付ける

Last updated at Posted at 2023-12-27

VPSマシンが悪意ある攻撃者に乗っ取られて攻撃の踏み台にされたりするのを防ぐ方法についてです。

通常、Linuxマシンは侵入と乗っ取りを防ぐためにリモートログインは次の認可・認証体制をしいていることがほとんどと思います。

  • 認証は公開鍵方式のみ。パスワードは使わない
  • rootにはログインできない。root権限が必要なら一般ユーザーからsudoコマンドを使わせる
    (rootがパスワードログインできるのはリモートでなく実機でだけにします。実機で許すのは、ssh壊れてにっちもさっちもいかなくなったときのためですね。実機に触れるという時点である程度の本人性が担保されていますし)

VPSもインスタンスを借りた時点からこういう構成になっていることがほとんどですが、海外の格安VPSなんかですと

  • グローバルからrootにパスワードでログインできる

状態のインスタンスをいきなりぽんと渡されたりします。
まずこの状態はセキュリティ上不十分であることを知っておいてください。パスワード認証は総当たり攻撃に弱く、それで侵入された時点でrootユーザーですからシステム全権限を乗っ取り完了となってしまいます。

さて、この状態から記事先頭に書いたまともな状態にしていきましょう。

手順です

  1. 鍵ペアを用意する
    もともと持っている方はOK。ない方は、ssh鍵ペアを用意します。用意の仕方はぐぐってくだされ。
  2. 自分用の一般ユーザーを用意する
    私yubaって名前なので、yubaって名前のユーザーを作ることにしますね。名前はお好きに。
    まずrootにそのパスワードを使って入ります。
    1. ユーザー作成
      useradd yuba
    2. ユーザーにsudoで管理権限を行使できるようにする
      通常Linuxではユーザーがwheelってグループに所属しているとsudoでrootの権限使えるようになってます
      usermod -G wheel yuba
    3. ユーザーがログインするための公開鍵を配置してやる
      まず自分の鍵ペアの公開鍵(id_rsa.pubのほう)の内容をクリップボードにコピーして乗せておきます
      mkdir /home/yuba/.ssh
      cat > /home/yuba/.ssh/authorized_keys そしてクリップボードをペーストしてからctrl D
      chown -R yuba:yuba /home/yuba/.ssh
      chmod 600 /home/yuba/.ssh/authorized_keys
    4. ユーザーにパスワードも設定してやる
      ログインには使わないのですがsudoコマンドを打ったときにパスワードを要求されてそこで詰むので、そのときに打てるパスワードを設定しておいてあげます。
      passwd yubad
  3. 公開鍵認証を有効にしパスワード認証を無効に
    vi /etc/ssh/sshd_config
    sshサーバーの設定ファイルをいじっていきます
    1. 公開鍵認証を有効にする
      PubkeyAuthenticationという行をみつけてonにします。先頭に#があったら消します。
    2. パスワード認証を無効に
      PasswordAuthenticationという行をみつけてoffにします。先頭に#があったら消します。
    3. rootにはsshで入れないようにする
      PermitRootLoginという行をみつけてoffにします。先頭に#があったら消します。
  4. 設定変更を適用
    service sshd reload
    さあ、まだrootユーザーをログアウトしてはいけません。
    ssh壊れてしまっていたらいきなりにっちもいかなくなりますからね。このログインセッションは最後まで命綱です。
  5. 確認
    1. 一般ユーザーで公開鍵ログインとsudoできることを確認
    2. rootユーザーにパスワードログインできなくなったことを確認
    3. すでにrootが何者かに侵入されていないかを確認
      いまさっきまで危ない状態でしたからね、一応すでに入られ済みでないか見ておきましょう。
      sudo grep "Accepted password" /var/log/secure
      自分がこの作業を開始したよりも前にこのログイン成功ログが残っていたらおかしい、侵入され済みかもとなります。ただ、時刻が日本時間とは限りませんからね、特に海外VPSだったりするなら。おかしいじゃんとあわてる前にタイムゾーンのご確認を。
  6. 完了
    確認がOKなら、もう一般ユーザーとして公開鍵認証で入り必要に応じてsudoするという一般的なセキュリティレベルが完成しています。
    これでもう、最初にログインしたrootのセッションは切っても大丈夫です。
3
3
0

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
3
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?