这里有新鲜出炉的 Nginx 开发从入门到精通,程序狗速度看过来!
Nginx 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本 0.1.0 发布于 2004 年 10 月 4 日。其将源代码以类 BSD 许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。
本篇文章主要介绍了 nginx 实现 tomcat 动静分离详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
1. 为什么要实现动静分离
1)nginx 的处理静态资源能力超强
主要是 nginx 处理静态页面的效率远高于 tomcat 的处理能力,如果 tomcat 的请求量为 1000 次,则 nginx 的请求量为 6000 次,tomcat 每秒的吞吐量为 0.6M,nginx 的每秒吞吐量为 3.6M,可以说,nginx 处理静态资源的能力是 tomcat 处理能力的 6 倍,优势可见一斑。
2) 动态资源和静态资源分开,使服务器结构更清晰。
2. 动静分离原理
服务端接收来自客户端的请求中,有一部分是静态资源的请求,例如 html,CSS,js 和图片资源等等,有一部分是动态数据的请求。因为 tomcat 处理静态资源的速度比较慢,所以我们可以考虑把所有静态资源独立开来,交给处理静态资源更快的服务器例如 nginx 处理,而把动态请求交给 tomcat 处理。
如下图所示,我们在机器上同时安装了 nginx 和 tomcat, 把所有的静态资源都放置在 nginx 的 webroot 目录下面,把动态请求的程序都放在 tomcat 的 webroot 目录下面,当客户端访问服务端的时候,如果是静态资源的请求,就直接到 nginx 的 webroot 目录下面获取资源,如果是动态资源的请求,nginx 利用反向代理的原理,把请求转发给 tomcat 进行处理,这样就实现了动静分离,提高了服务器处理请求的性能。
3. 动静分离的详细配置
1) 首先熟悉下 nginx 的重要配置文件 nginx.conf
- user nginx;
- worker_processes 1;
- error_log logs / error.log;
- pid logs / nginx.pid;
- events {
- worker_connections 1024;
- }
- http {
- include 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 logs / access.log main;
- sendfile on;
- keepalive_timeout 65;#gzip压缩功能设置gzip on;
- gzip_min_length 1k;
- gzip_buffers 4 16k;
- gzip_http_version 1.0;
- gzip_comp_level 2;
- gzip_types text / plain application / x - javascripttext / css application / xml;
- gzip_vary on;
- server {
- listen 80;
- server_name www.test.com;
- location / {#jsp网站程序根目录,一般nginx与tomcat在同一个目录root / usr / local / tomcat / webapps / ROOT;
- index index.html index.jsp index.html;
- }
- location~. * .jsp$ {
- index index.jsp;
- proxy_pass http: //127.0.0.1:8080; #来自jsp请求交给tomcat处理
- proxy_redirect off;
- proxy_set_header Host $host;#后端的Web服务器可以通过X - Forwarded - For获取用户真实IP proxy_set_header X - Real - IP $remote_addr;
- proxy_set_header X - Forwarded - For $proxy_add_x_forwarded_for;
- client_max_body_size 10m;#允许客户端请求的最大单文件字节数client_body_buffer_size 128k;#缓冲区代理缓冲用户端请求的最大字节数proxy_connect_timeout 90;#nginx跟后端服务器连接超时时间 (代理连接超时) proxy_read_timeout 90;#连接成功后,后端服务器响应时间 (代理接收超时) proxy_buffer_size 4k;#设置代理服务器(nginx)保存用户头信息的缓冲区大小proxy_buffers 6 32k;#proxy_buffers缓冲区,网页平均在32k以下的话,这样设置proxy_busy_buffers_size 64k;#高负荷下缓冲大小(proxy_buffers * 2)proxy_temp_file_write_size 64k;#设定缓存文件夹大小,大于这个值,将从upstream服务器传
- }
- location~. * \. (gif | jpg | png | bmp | swf) $#由nginx处理静态页面 {
- expires 30d;#使用expires缓存模块,缓存到客户端30天
- }
- location~. * \. (jsp | js | css) ? $ {
- expires 1d;
- }
- error_page 404 / 404.html;#错误页面error_page 500 502 503 504 / 50x.html;
- location = /50x.html {
- root html;
- }
- }
- /
2) 配置动静分离
- #配置Nginx动静分离,定义的静态页面直接从Nginx发布目录读取。location~. * \. (html | htm | gif | jpg | jpeg | bmp | png | ico | txt | js | css) $ {
- root / webapps / myproject / code / static - resource;#expires定义用户浏览器缓存的时间为7天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力expires 1d;
- }
- location~ ^ /(WEB-INF)/ {#这个很重要,不然用户就可以访问了deny all;
- }
这里需要注意,外部静态文件的存放路径,应当与请求中路径一致,以免 nginx 拼接路径后,由于路径不存在而找不到文件。如果出现 js、css 等不加载的情况,可以查看 nginx 的 errorlog 进行调试修正,日志位于 nginx 目录下的 logs 目录内, 如下截取一段错误的日志:
- [error] 7195#0 : *1693 open()"/home/cms/include/dedeajax2.js"failed(2 : No such file or directory),
- client: 101.226.35.225,
- server: localhost,
- request: "GET /cms/include/dedeajax2.js HTTP/1.1"
可以看到,GET 请求是 "/cms/include/dedeajax2.js",这时 nginx 就会在配置中的 /home 下,寻找这一路径的文件,完整路径为:
- /home/cms / include / dedeajax2.js
报错为 no such file or directory ,就可以在对应的 /home 目录下看文件路径的问题。
配置成功后,就可以发现静态文件通过 nginx 处理了,静态文件的请求不再进入 tomcat 服务器,从而可以打包时,静态文件的目录如 js、css 等不再打进 war 包。
来源: http://www.phperz.com/article/17/0716/336668.html