You are browsing Nuxt 2 docs. Go to Nuxt 3 docs, or learn more about Nuxt 2 Long Term Support.
リバースプロキシとして NGINX を使う
リバースプロキシとして NGINX の使い方
map $sent_http_content_type $expires {
"text/html" epoch;
"text/html; charset=utf-8" epoch;
default off;
}
server {
listen 80; # nginxがリッスンしているポート
server_name your-domain; # ここにドメインをセットアップ
gzip on;
gzip_types text/plain application/xml text/css application/javascript;
gzip_min_length 1000;
location / {
expires $expires;
proxy_redirect off;
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;
proxy_read_timeout 1m;
proxy_connect_timeout 1m;
proxy_pass http://127.0.0.1:3000; # ここに Node.js インスタンスのアドレスを設定
}
}
生成されたページとフォールバックとしてキャッシングプロキシを使用した nginx
コンテンツが定期的に変更される大容量のウェブサイトをお持ちの場合、Nuxt の生成機能とnginx caching の恩恵を受けることができるでしょう。
以下に設定例を示します。覚えてください:
- ルートフォルダは、generate.dir の設定 で設定したものと同じである必要があります。
- Nuxt で設定された期限切れのヘッダーは削除されます(キャッシュがあるため)。
- Nuxt と nginx の両方で追加のヘッダーを設定できますが、どちらかを選択することをお勧めします(迷ったら nginx を選択してください)。
-
サイトのほとんどが静的なものであれば、
proxy_cache_path inactive
とproxy_cache_valid
の値を増やしてください。
ルートを生成しなくても、nginx のキャッシュの恩恵を受けたい場合:
-
root
エントリを削除 -
location @proxy {
をlocation / {
に変更 -
他 2
location
エントリを削除
proxy_cache_path /data/nginx/cache levels=1:2 keys_zone=nuxt-cache:25m max_size=1g inactive=60m use_temp_path=off;
map $sent_http_content_type $expires {
"text/html" 1h; # これが必要なら設定
"text/html; charset=utf-8" 1h; # これが必要なら設定
default 7d; # これが必要なら設定
}
server {
listen 80; # nginx がリッスンするポート
server_name your-domain; # ここにドメインをセットアップ
gzip on;
gzip_types text/plain application/xml text/css application/javascript;
gzip_min_length 1000;
charset utf-8;
root /var/www/NUXT_PROJECT_PATH/dist;
location ~* \.(?:ico|gif|jpe?g|png|woff2?|eot|otf|ttf|svg|js|css)$ {
expires $expires;
add_header Pragma public;
add_header Cache-Control "public";
try_files $uri $uri/ @proxy;
}
location / {
expires $expires;
add_header Content-Security-Policy "default-src 'self' 'unsafe-inline';";
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload" always;
add_header X-Frame-Options "SAMEORIGIN";
try_files $uri $uri/index.html @proxy; # generate.subFolders: true 向け
# try_files $uri $uri.html @proxy; # generate.subFolders: false 向け
}
location @proxy {
expires $expires;
add_header Content-Security-Policy "default-src 'self' 'unsafe-inline';";
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload" always;
add_header X-Frame-Options "SAMEORIGIN";
add_header X-Cache-Status $upstream_cache_status;
proxy_redirect off;
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;
proxy_ignore_headers Cache-Control;
proxy_http_version 1.1;
proxy_read_timeout 1m;
proxy_connect_timeout 1m;
proxy_pass http://127.0.0.1:3000; # ここに Node.js インスタンスのアドレスを設定
proxy_cache nuxt-cache;
proxy_cache_bypass $arg_nocache; # これは変更した方がよいでしょう
proxy_cache_valid 200 302 60m; # これが必要なら設定
proxy_cache_valid 404 1m; # これが必要なら設定
proxy_cache_lock on;
proxy_cache_use_stale error timeout http_500 http_502 http_503 http_504;
proxy_cache_key $uri$is_args$args;
}
}
#Laravel Forge 向けの nginx 設定:
YOUR_WEBSITE_FOLDER
をウェブサイトのフォルダに、YOUR_WEBSITE_DOMAIN
をウェブサイトのURLに変更してください。Laravel Forge がこれらの値を入力してくれていますが、必ず再確認してください。
# FORGE 設定 (削除しないでください!)
include forge-conf/YOUR_WEBSITE_FOLDER/before/*;
map $sent_http_content_type $expires {
"text/html" epoch;
"text/html; charset=utf-8" epoch;
default off;
}
server {
listen 80;
listen [::]:80;
server_name YOUR_WEBSITE_DOMAIN;
add_header X-Frame-Options "SAMEORIGIN";
add_header X-XSS-Protection "1; mode=block";
add_header X-Content-Type-Options "nosniff";
charset utf-8;
gzip on;
gzip_types text/plain application/xml text/css application/javascript;
gzip_min_length 1000;
# FORGE 設定 (削除しないでください!)
include forge-conf/YOUR_WEBSITE_FOLDER/server/*;
location / {
expires $expires;
proxy_redirect off;
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;
proxy_read_timeout 1m;
proxy_connect_timeout 1m;
proxy_pass http://127.0.0.1:3000; # ここに Node.js インスタンスのアドレスを設定
}
access_log off;
error_log /var/log/nginx/YOUR_WEBSITE_FOLDER-error.log error;
location ~ /\.(?!well-known).* {
deny all;
}
}
# FORGE 設定 (削除しないでください!)
include forge-conf/YOUR_WEBSITE_FOLDER/after/*;
TLS で Laravel Forgeをセキュアにする
Laravel Forge に nginx.conf
の編集を任せるのが一番良いでしょう、Sitesをクリックして → YOUR_WEBSITE_DOMAIN(SERVER_NAME)をクリックし、SSL をクリックして、いずれかのプロバイダーの証明書をインストールします。証明書を有効にすることを忘れないでください。これであなたの nginx.conf
は以下のようになるはずです:
# FORGE 設定 (削除しないでください!)
include forge-conf/YOUR_WEBSITE_FOLDER/before/*;
map $sent_http_content_type $expires {
"text/html" epoch;
"text/html; charset=utf-8" epoch;
default off;
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name YOUR_WEBSITE_DOMAIN;
# FORGE 設定 (削除しないでください!)
ssl_certificate /etc/nginx/ssl/YOUR_WEBSITE_FOLDER/258880/server.crt;
ssl_certificate_key /etc/nginx/ssl/YOUR_WEBSITE_FOLDER/258880/server.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers 'ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-DSS-AES128-GCM-SHA256:kEDH+AESGCM:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:DHE-DSS-AES128-SHA256:DHE-RSA-AES256-SHA256:DHE-DSS-AES256-SHA:DHE-RSA-AES256-SHA:AES128-GCM-SHA256:AES256-GCM-SHA384:AES128-SHA256:AES256-SHA256:AES128-SHA:AES256-SHA:AES:CAMELLIA:DES-CBC3-SHA:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!MD5:!PSK:!aECDH:!EDH-DSS-DES-CBC3-SHA:!EDH-RSA-DES-CBC3-SHA:!KRB5-DES-CBC3-SHA:!3DES';
ssl_prefer_server_ciphers on;
ssl_dhparam /etc/nginx/dhparams.pem;
add_header X-Frame-Options "SAMEORIGIN";
add_header X-XSS-Protection "1; mode=block";
add_header X-Content-Type-Options "nosniff";
charset utf-8;
gzip on;
gzip_types text/plain application/xml text/css application/javascript;
gzip_min_length 1000;
# FORGE 設定 (削除しないでください!)
include forge-conf/YOUR_WEBSITE_FOLDER/server/*;
location / {
expires $expires;
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;
proxy_redirect off;
proxy_read_timeout 1m;
proxy_connect_timeout 1m;
proxy_pass http://127.0.0.1:3000; # ここに Node.js インスタンスのアドレスを設定
}
access_log off;
error_log /var/log/nginx/YOUR_WEBSITE_FOLDER-error.log error;
location ~ /\.(?!well-known).* {
deny all;
}
}
# FORGE 設定 (削除しないでください!)
include forge-conf/YOUR_WEBSITE_FOLDER/after/*;
このページをGitHubで編集する
更新日 Mon, Aug 19, 2024
data:image/s3,"s3://crabby-images/ad1e0/ad1e0ccc71f56428cac057a18935a7f0e5aa2179" alt="Sébastien Chopin"
data:image/s3,"s3://crabby-images/280e2/280e20bbe020dcc29646bedb3503b8f655215f6d" alt="Nazaré da Piedade"
data:image/s3,"s3://crabby-images/7b950/7b9506feb470a82c7d7c2f664775316b2d979db8" alt="Nobu"
data:image/s3,"s3://crabby-images/b5a1a/b5a1a1cfdf10f35ca2693a4ff3f3b666dafda47b" alt="川音리오"
data:image/s3,"s3://crabby-images/476b5/476b5a7a3778c9761407fa2fa62eb586b08617f1" alt="Maciek Palmowski"
data:image/s3,"s3://crabby-images/74511/745117264de1baefa42ed45ec061dee5288da470" alt="Nestor Vera"
data:image/s3,"s3://crabby-images/32280/32280ac192b216ce7afa1c73452da9cbf5f488c4" alt="Daniel Roe"
data:image/s3,"s3://crabby-images/e5c13/e5c13a0213ffc2b00fc5326dbf11708d445f6c41" alt="Yue Yang"
data:image/s3,"s3://crabby-images/23eb1/23eb1f9c15d8ad7ae0a003eb1aa20aaf2d358b8c" alt="Jeronimas"
data:image/s3,"s3://crabby-images/7cadf/7cadf7804e70fc1a5fc1a44dcfaef2a0db7b7cfb" alt="Clément Ollivier"
data:image/s3,"s3://crabby-images/bdb3e/bdb3e5a67c82871afdd7bbc4301d195cd72da1df" alt="Alexander Lichter"
data:image/s3,"s3://crabby-images/6dc6b/6dc6b8c92c9ffe8287d388c7e0e2d9712cc9e093" alt="N3-rd"
data:image/s3,"s3://crabby-images/43d48/43d48d49ad7ef86b399a980da5edc6b259762a71" alt="Adrien Zaganelli"
data:image/s3,"s3://crabby-images/7684a/7684a7c81129c7aa02ebe3e38ba8649f1febcfb0" alt="Mag"
data:image/s3,"s3://crabby-images/463bc/463bc0c5fccb19537ab885f3c7f62ef2e0e8e131" alt="Stefan Huber"
data:image/s3,"s3://crabby-images/549d7/549d7e9703c74a315f65fdb3bdd5dec0ec54d3d6" alt="Olga Bulat"
data:image/s3,"s3://crabby-images/3b9b4/3b9b475f7992ead45688540a6816460366946c93" alt="Paiva"
data:image/s3,"s3://crabby-images/d6563/d656313bf9a954a95778c37c68cf7f9402c304ca" alt="Florian Reuschel"
data:image/s3,"s3://crabby-images/6905b/6905b8dacd5454c9ae3192e12ac7c83130cdcdfd" alt="Savas Vedova"
data:image/s3,"s3://crabby-images/41ee3/41ee35a4e665d9a800ca0bae0eebb7f33cf0f981" alt="HIJACK"
data:image/s3,"s3://crabby-images/0e0fd/0e0fd3b04e57f0fdcdf6ca052b2e4809b3f773a3" alt="Vinícius Alves"
data:image/s3,"s3://crabby-images/26495/264956020fb2206480d15b45df7e4c3077443c29" alt="Kareem Dabbeet"
data:image/s3,"s3://crabby-images/93a63/93a635e2a0b73a2839f6f4162012de047cf3c1bf" alt="Valentín Costa"
data:image/s3,"s3://crabby-images/96b5d/96b5d4494b5a24353b285efcf1bda83886bb6b2c" alt="Ryan Skinner"
data:image/s3,"s3://crabby-images/f9a47/f9a473f36fc9a4c28511d5753a9cedc251e7794d" alt="Alex Hirzel"
data:image/s3,"s3://crabby-images/0577f/0577f8239ac9f5cbd843473d76787f54a394e0c3" alt="Ajeet Chaulagain"
data:image/s3,"s3://crabby-images/bc92b/bc92b2a810967ec7fbe87e81544104a104535984" alt="René Eschke"
data:image/s3,"s3://crabby-images/7e9a6/7e9a672752999d8af2ab5afd464e0b048790b2cf" alt="Nico Devs"
data:image/s3,"s3://crabby-images/606b5/606b57e73f5182629718152e9e2f6733dc5930d9" alt="Muhammad"
data:image/s3,"s3://crabby-images/749c4/749c40d8d89b3992aa3c625d31f20e3156cd614d" alt="Naoki Hamada"
data:image/s3,"s3://crabby-images/281f3/281f32fc092112fbf8adce5d887894471e14e1af" alt="Tom"
data:image/s3,"s3://crabby-images/8fee4/8fee4fdb4c1e0ecbc880aa4a4345f3cfa491d698" alt="Yann Aufray"
data:image/s3,"s3://crabby-images/3486d/3486d5077ad2709bc3ca037b54859186beae0738" alt="Anthony Chu"
data:image/s3,"s3://crabby-images/fad12/fad1229119c600cb55ac954ce2f9755608acad1e" alt="Nuzhat Minhaz"
data:image/s3,"s3://crabby-images/1f8ef/1f8ef0c9cd1d4c5edc8953acf54dd42ee657f225" alt="Lucas Portet"
data:image/s3,"s3://crabby-images/26089/2608940075c4cb0b64522dfa622859e022fc1ab4" alt="Richard Schloss"
data:image/s3,"s3://crabby-images/d04c4/d04c4b51f71b1f578f03e2349263f2569ec96bca" alt="Bobby"
data:image/s3,"s3://crabby-images/f8159/f81596a3834abf16fd4fe859119d6ea4ba599b2e" alt="bpy"
data:image/s3,"s3://crabby-images/c4ce0/c4ce0af1786309ff212b6623167dbc4bd20e7533" alt="Antony Konstantinidis"
data:image/s3,"s3://crabby-images/9c9be/9c9be15865ec34a7fbac824d2b3321874ce42240" alt="Hibariya"
data:image/s3,"s3://crabby-images/54ac1/54ac182efe4081cfc30358b7a8aa40a67554477b" alt="Jose Seabra"
data:image/s3,"s3://crabby-images/e1fe9/e1fe99db1e19a55e81f67c879e231166af19b1b1" alt="Eze"
data:image/s3,"s3://crabby-images/301b4/301b4fef68db4605b94f474ce5eb669e10f7536e" alt="Florian Lefebvre"
data:image/s3,"s3://crabby-images/c93f7/c93f7970ecfbfeacbda8bf4effe7d1daa3355f60" alt="Lucas Recoaro"
data:image/s3,"s3://crabby-images/c1cc3/c1cc36bdcc7a61b00fe5ec7fc1bd923df9b828ef" alt="Julien SEIXAS"