株式会社エスロジカル
株式会社エスロジカル
SSL証明書(DV、OV、EV)、セキュリティ、Web開発、Linux開発、Go言語

HOME > 技術ドキュメント > Nginx SSL/TLS 設定(Ubuntu 24.04)

Nginx SSL/TLS 設定(Ubuntu 24.04 LTS)


Ubuntu 24.04 LTS への Nginx インストールと SSL/TLS(HTTPS)設定を解説します。
TLS 1.2/1.3 への対応、HTTP → HTTPS リダイレクト、バーチャルホストの設定まで順を追って説明します。


sudo apt update
sudo apt install -y nginx

# バージョン確認
nginx -v
# nginx version: nginx/1.24.x

# 起動・自動起動
sudo systemctl start nginx
sudo systemctl enable nginx

sudo ufw allow 'Nginx Full'
sudo ufw enable
sudo ufw status

取得した SSL証明書ファイルをサーバーに配置します。
証明書の取得方法は 購入から発行までの流れ をご参照ください。

# 証明書と秘密鍵を配置(パスは任意)
sudo cp your_domain.crt /etc/ssl/certs/your_domain.crt
sudo cp your_domain.key /etc/ssl/private/your_domain.key
sudo chmod 600 /etc/ssl/private/your_domain.key

# 中間証明書を結合する場合(フルチェーン)
cat your_domain.crt intermediate.crt > /etc/ssl/certs/your_domain_fullchain.crt

/etc/nginx/sites-available/example.com を作成します。

# HTTP → HTTPS リダイレクト
server {
    listen 80;
    server_name example.com www.example.com;
    return 301 https://www.example.com$request_uri;
}

# HTTPS 設定
server {
    listen 443 ssl;
    server_name www.example.com;

    ssl_certificate     /etc/ssl/certs/your_domain_fullchain.crt;
    ssl_certificate_key /etc/ssl/private/your_domain.key;

    # TLS バージョン(1.2 以上を許可)
    ssl_protocols TLSv1.2 TLSv1.3;

    # セキュアな暗号スイート
    ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384;
    ssl_prefer_server_ciphers off;

    # HSTS(HTTPS を強制)
    add_header Strict-Transport-Security "max-age=63072000" always;

    root /var/www/example.com;
    index index.html index.htm;

    location / {
        try_files $uri $uri/ =404;
    }
}
# シンボリックリンクで有効化
sudo ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/

# 設定ファイルの構文確認
sudo nginx -t

# 反映
sudo systemctl reload nginx

設定後は SSL証明書インストールチェッカー で 中間証明書が正しくインストールされているか確認することをお勧めします。
また、外部ツール(SSL Labs Server Test 等)で TLS の設定強度を確認できます。


Go 言語で作成した Web アプリ(例::8080 で動作)を Nginx 経由で公開する設定例です。

server {
    listen 443 ssl;
    server_name api.example.com;

    ssl_certificate     /etc/ssl/certs/your_domain_fullchain.crt;
    ssl_certificate_key /etc/ssl/private/your_domain.key;
    ssl_protocols TLSv1.2 TLSv1.3;

    location / {
        proxy_pass         http://127.0.0.1:8080;
        proxy_http_version 1.1;
        proxy_set_header   Host              $host;
        proxy_set_header   X-Real-IP         $remote_addr;
        proxy_set_header   X-Forwarded-For   $proxy_add_x_forwarded_for;
        proxy_set_header   X-Forwarded-Proto $scheme;
    }
}

Nginx に設定する SSL証明書は、エスロジカルで低価格販売しています。
デジサート・サイバートラストの正規取扱代理店として、 RapidSSL 3,960円/1年(税込)〜 で 2009年から 16年以上販売。インストール代行も承ります。

SSL証明書の購入はこちら / DV・OV・EV の違い / インストール代行サービス


← 技術ドキュメント一覧へ戻る