nginx 具备将资源文件(js、html、htm、css、png、css 等)无需动态处理的静态文件和应用服务器分离,释放应用服务器在处理这些静态文件时的压力,优化并提高应用服务器的性能,而静态文件可以在 nginx 的其它目录中,或者来自其它服务器。
应用服务器的 URL:http://192.168.2.10:8080/myapp,通过反向代理映射到 localhost/myapp,而 myapp 的资源文件放到了 /usr/local/website_resource/ 目录内,这里面同样需要对应一个 myapp 的目录与 URL 里面 myapp 对应,而 scripts 和 styles 之类的静态内容就放到 myapp 目录中,也就是这样 /usr/local/website_resource/myapp。
当 http://localhost/myapp 被访问时,动态信息将在反向代理的帮助下由 http://192.168.2.10:8080/myapp 读取,而相应的 scripts 和 styles 则来自 nginx 服务器的 /usr/local/website_resource/myapp 内的 script 和 style,这些静态内容文件将不再成为应用服务器的负担。
以下是 nginx 配置动静态分离的配置,关键点在第二个 location 后面的正则:
server {
listen 80;
server_name localhost;
access_log logs/localhost-access.log;
error_log logs/localhost-error.log;
#参考资料
#http://nginx.org/en/docs/http/ngx_http_proxy_module.html
location /myapp/ {
root html;
index index.html index.htm;
proxy_pass http://192.168.2.10:8080/myapp/;
proxy_cookie_path /myapp /myapp;
#proxy_set_header Host $host;
proxy_set_header proxy_remote_addr $remote_addr; #客户端实际地址
proxy_set_header proxy_add_x_forwarded_for $proxy_add_x_forwarded_for; #多级代理情况下客户端地址
}
location ~ .*\.(html|htm|gif|jpg|jpeg|js|png|css|ico|bmp|json|ftt|svg|woff)$ {
root "/usr/local/website_resource/";
expires 30d;
}
}
location 的正则是表示对应的路径下的相应扩展名的文件 ~ .*\.(html|htm|gif|jpg|jpeg|js|png|css|ico|bmp|json|ftt|svg|woff)$,这些文件将去 root "/usr/local/website_resource/" 这里寻找,缓存时间 30d (day)
资源目录位置:/usr/local/website_resource/,目录内同样有一个与应用程序名相同的 myapp 目录,与应用服务器中的 location /myapp/ 匹配,这里名字必须对应。
相应的 /usr/local/website_resource/myapp/ 目录内就是 myapp 应用所需要的 scripts 和 styles,被匹配的资源(静态)文件将不再由应用服务器发送,而是由 nginx 直接发送,这降低了应用服务器的读取压力,释放了应用服务器的性能,同时也提高了客户体验。但这个设置在客户端数量达到一定程度上才会有所体现,若客户端数量太少的话也凸显不出这种配置的优势。
设置完毕后,保存 nginx 配置文件,重启 nginx 服务器即可。
# 启动 nginx
>nginx
# 关闭 nginx
>nginx -s stop
https://blog.inull.net
Q群讨论236201801
.