nginxでSSIを適用させる
Google Compute Engine(GCE)にnginxをインストールしました。今回はSSIを使える用にしたいと思います
今回の目的
- GCEにインストールしたnginxにSSIを適用させる
- SSIは拡張子htmlで動かしたい
普段はApacheを使っている僕なので、htaccessを使ってSSIの設定をしますがnginxではhtaccessを使う事ができません。そこでconfファイルに直接書きます。
/etc/nginx/nginx.confを編集
設定ファイルをいじることでできるみたいです。というわけでやってみます
[macan@instance-1 www]$ sudo cat /etc/nginx/nginx.conf user nginx; worker_processes 1; error_log /var/log/nginx/error.log warn; pid /var/run/nginx.pid; events { worker_connections 1024; } http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; keepalive_timeout 65; #gzip on; include /etc/nginx/conf.d/*.conf; } [macan@instance-1 www]$
デフォルトのままだとこんな感じです。というわけでSSIの読み込む設定をします。
設定
http { server { location / { ssi on; ssi_last_modified on; } } }
こんな風にするらしいです。というわけでデフォルトに合わせて書いていきます。
書いてみました
[macan@instance-1 www]$ sudo cat /etc/nginx/nginx.conf user nginx; worker_processes 1; error_log /var/log/nginx/error.log warn; pid /var/run/nginx.pid; events { worker_connections 1024; } http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; keepalive_timeout 65; #gzip on; include /etc/nginx/conf.d/*.conf; server{ location / { ssi on; ssi_last_modified on; } } } [macan@instance-1 www]$
チェックします。
[macan@instance-1 www]$ sudo nginx -t nginx: the configuration file /etc/nginx/nginx.conf syntax is ok nginx: configuration file /etc/nginx/nginx.conf test is successful
OKがでました。これでSSIはOKです。実際に試してみました。
動かない・・・
結論:NGでした。というわけで大人しくファイルを変更します。
/etc/nginx/conf.d/default.confに記述
default.confに記述してみます。
[macan@instance-1 html]$ sudo cat /etc/nginx/conf.d/default.conf server { listen 80; server_name localhost; #charset koi8-r; #access_log /var/log/nginx/host.access.log main; location / { #root /usr/share/nginx/html; root /var/www/html; ssi on; ssi_last_modified on; index index.html index.htm; } #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html; } # proxy the PHP scripts to Apache listening on 127.0.0.1:80 # #location ~ \.php$ { # proxy_pass http://127.0.0.1; #} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 # #location ~ \.php$ { # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # #location ~ /\.ht { # deny all; #} }
動いた
この設定だけで、拡張子htmlでもSSIが動きました。これは嬉しいですね。
個人支援・寄付について
サイトラボでは個人支援・寄付を受けております。ご協力いただける方はお願いいたします。当サイトではビットコインで受け付けております。
- ビットコイン:3LHnADwZwUbic2L45EnVJEykiG6KfbqrwS