はじめに
諸事情によりUbuntu Serverを導入したけど、セキュリティ設定に手間取ったので今後のためにもメモとして記事に残しっておこうという感じです。
注意
あくまでセキュリティ設定の一例(一部)をご紹介するレベルです。
サーバ運用する上でセキュリティを担保するためには本記事で紹介する項目以外にも使用するミドルウェアやプロダクトに対してセキュアな設定を行う必要があります。
環境
「Ubuntu 24.04.2 LTS」です。
設定項目
以下の設定の仕方を本記事では記載しています。
- Firewall(ufw)
- SSHサーバ設定
- TCPwrapper
- Anti-Virus(Clamav)
次節から上記項目の内容の設定例を記載していきます。
Firewall
今回はufwを使用しましたので、設定方法の例を記載します。
今回の環境(Ubuntu 24.04.2 LTS)には、デフォルトでufwがインストールされておりましたので設定から始めています。
まずは、ufwをアクティブ化する必要があります。
$ sudo ufw status
Status: inactive '初期は非アクティブ状態のため、アクティブにする必要があります'
$ sudo ufw enable
$ sudo ufw status
Status: active 'アクティブ化されていることを確認!'
デフォルト設定は以下のコマンド確認可能です。
$ sudo ufw status verbose
Status: active
Logging: on (low)
Default: deny (incoming), allow (outgoing), disabled (routed)
デフォルト設定内容
- 外部から内部への通信(incoming)は、拒否となっており遮断されています
- 内部から外部へ通信(outgoing)は、許可となっています
このままだと、SSHを使用してリモート操作できないためSSHのポートを開放します。
$ sudo ufw allow 22/tcp
これは、これでOKですが、外部公開サーバで行う場合は、以下の観点でセキュリティを意識すると物足りない感じがあります。
- SSHのポートが「22」はウェルノウンポートで、外部の攻撃者からの攻撃を受けやすい
- 通信元が絞られていないため、不特定のネットワークセグメントから通信を許可されている
1.については、次節のSSHの設定でポート番号を変更して待受ける方法を提示します。
仮にここでは、待受ポートを仮に「1022」にした場合の設定例を記載します。
'通信元のアドレスセグメント:10.32.0.0'
'自(通信先)サーバIPアドレス:10.32.0.xx'
$ sudo ufw allow from 10.32.0.0/24 to 10.32.0.xx port 1022 proto tcp
自サーバに複数のネットワークインターフェース(NIC)がある場合はネットワークインターフェースを絞ることでよりセキュアに扱えると思います。
この設定は@teyama3さんが公開している「UFWを活用して特定の通信のみ許可する」という記事がわかりやすいです。
SSHサーバ設定
セキュアにリモート操作するためには、待受ポートや認証方法を制限する必要があります。
公開鍵認証にして、セキュリティを高めた方が良いと思います。
ここが手間取ったところになります。
一昔前は設定を記載するファイルは「/etc/ssh/sshd_config」でした。
最近のOpenSSHは設定ファイルが別にあります。
「/etc/ssh/sshd_config.d/.conf」です。*
「/etc/ssh/sshd_config」に以下の記載があり、「/etc/ssh/sshd_config.d/」配下にあるconfファイルを
読み込みます。
Include /etc/ssh/sshd_config.d/*.conf
読み込んだconfファイルの内容が優先されます。
「/etc/ssh/sshd_config.d/50-cloud-init.conf」が既に存在しており以下の記載がされています。
PasswordAuthentication yes
パスワード認証を有効にする設定が記載されています。
パスワード認証を不可にしたい場合、「/etc/ssh/sshd_config.d/」の読み込まれる優先度についても考慮する必要があります。
「/etc/ssh/sshd_config.d/」配下のconfファイルの読み込み優先度
ファイルの名前順に読み込まれ、先に読み込まれた設定が優先されます。
今回は「10-custom.conf」という名前でSSHサーバの設定ファイルを記載します。
#待受ポート設定
Port 1022
#プロトコルバージョン1は脆弱性があるため、バージョン2のみ受付けるようにする。
Protocol 2
#rootログインを拒否する
PermitRootLogin no
#SSHバージョン1での公開鍵認証を拒否する。Protocolで使用できるバージョンを絞っているが念のため設定
RSAAuthentication no
#SSHバージョン2で公開鍵認証を許可する
PubkeyAuthentication yes
#空パスワードを拒否する
PermitEmptyPasswords no
#パスワード認証拒否する
PasswordAuthentication no
# ログイン試行回数を制限する(3回)
MaxAuthTries 3
#ログイン試行時間を制限する(30秒)
LoginGraceTime 30
#SSHを利用するユーザを制限する
AllowUsers User
公開鍵の作成方法
以下の手順で公開鍵を作成して、サーバに登録します。
$ ssh-keygen -t ed25519
$ cat publickey >> ~/.ssh/authorized_keys
$ chmod 600 ~/.ssh/authorized_keys
'publickeyはもう不要なので削除する'
$ rm publickey
TCPwrapper
TCPWrapperはホスト名やIPアドレスによってアクセス制御を行うことができます。
許可内容を記載する「/etc/hosts.allow」と拒否内容を記載する「/etc/hosts.deny」で設定します。
sshd: 10.32.0.
ALL: ALL
/etc/hosts.denyで全てのアクセスを禁止した上で、/etc/hosts.allowで許可する対象を追加するのが、抜け漏れなく設定するポイントです。
/etc/hosts.allowで「10.32.0.」は書き損じではありません。
10.32.0.0/24セグメントをしています。つまり、第4オクテットのワイルドカード「10.32.0.*」を意味しています。
Anti-Virus(Clamav)
Linuxで使用できるウイルス対策ソフトはほぼ商用版であり、一般家庭向け用に導入できるものは少ないです。
そこでオープンソースのウイルス対策ソフトであるClamavを導入します。
導入方法は公式サイトに記載の通りコマンド実行します。
$ sudo apt install clamav
$ sudo apt install clamav-daemon
$ sudo systemctl start clamav-daemon
$ sudo systemctl enable clamav-daemon
ウィルス定義の更新
以下コマンドで実施するが、エラーが発生します。
$ sudo freshclam
ERROR: /var/log/clamav/freshclam.log is locked by another process
ERROR: Problem with internal logger (UpdateLogFile = /var/log/clamav/freshclam.log).
ERROR: initialize: libfreshclam init failed.
ERROR: Initialization error!
対象方法
- ログファイルを一度削除する
- ログローテートの設定を変更する
$ sudo rm /var/log/clamav/freshclam.log
$ sudo touch /var/log/clamav/freshclam.log
$ sudo chown clamav:clamav /var/log/clamav/freshclam.log
$ sudo vim /etc/logrotate.d/clamav-freshclam
<修正箇所>
create 640 clamav adm
↓
create 640 clamav clamav
ウィルススキャン
/homeディレクトリを再帰的に対象としてスキャンする方法は以下です。
$ cd
$ sudo clamscan -r
ウィルスを検知しても自動で削除されないため、スキャン時に自動削除する場合は以下のようにします。
$ sudo clamscan --remove
参考資料
- UFWを活用して特定の通信のみ許可する
- SSH公開鍵認証で接続するまで
- PasswordAuthenticationで躓いたお話
- Ubuntu22.04 sshdでPasswordAuthentication noが効かない
- clamAV
- 【徹底解説】Ubuntu22.04にClamAVをインストール・設定する方法!
- Ubuntu 20.04にClamAVというアンチウイルスソフトをインストールする
- 【Ubuntu 20.04/18.04 LTS Server】ClamAVで定期的にウイルスチェックし、メール通知する
- 【2024年08月版】Ubuntu でウイルス対策【clamav】
諸事情
記事とは直接関係ないけど、Desktop版を使用したという思いもあるので解決策をお持ちの方がいらっしゃればご教授ください!
24.04.02 LTS Desktopにアップグレードしたら、またGUI起動しなくなった。
— LittleBear🐻 (@littlebear_6w6) March 8, 2025
ということで、最初から24.04.02 LTS Desktopを入れてやるぜということで、isoをダウンロード中。
↑学習能力ないだろうと突っ込まれればそれまでだけど、やります。
次ダメなら、Server版入れてSSHで使おう。 https://t.co/p6c8whvcrv
SSH設定に手こずったのでQiitaにメモを作ろう!
— LittleBear🐻 (@littlebear_6w6) March 9, 2025