Nginx与Tomcat实现请求动态数据与请求静态资源的分离

  上篇博客说明了Nginx在应用架构中的作用,以及负载均衡的思路。这篇实践一下其中的访问静态资源与访问动态资源的操作。

一、认识访问静态资源与访问动态资源的区别

  静态资源:指存储在硬盘内的数据,固定的数据,不需要计算的数据。

  如:图片、字体、js文件、css文件等等。在用户访问静态资源时,服务器会直接将这些资源返回到用户的计算机内。

  

  动态资源:指需要服务器根据用户的操作所返回的数据,以及存储在数据库的数据,经过一系列逻辑计算后返回的数据。

  如:请求明天的天气信息数据、请求查看账户余额。

二、请求动态数据与请求静态资源的分离的必要性

  Tomcat应用服务器是用来处理Servlet容器和JSP的,虽然它也可以处理HTML等等一系列静态资源,但是效率不如Nginx;而且对Servlet容器和JSP的运算已经有很大压力了,如果不分离会导致大量的性能浪费。说到底,在应用服务方面,要遵循一条原则——一个服务只做一件事。要做动态请求就专做动态请求,要做静态请求就专做静态请求,这样才能提高性能。

   

  我们要做的,就是当用户访问静态资源时,让Nginx将静态资源返回给用户;当用户访问动态资源时,将访问转到Tomcat应用服务器上,Tomcat将数据返回给Nginx,Nginx再返回给用户。

三、Nginx配置方法

  在这里,对于Nginx的配置文件内的各项参数说明不多讲解,如需了解Nginx配置文件移步这里

  不知道配置文件位置的,一条指令:

sudo find / -name nginx.conf

  要善于利用Linux指令,这样就会无法自拔的爱上Linux;

  先来一个全部配置:

  

  1 # user www www;
  2 user root root;
  3
  4 worker_processes 2; #设置值和CPU核心数一致
  5
  6 error_log /home/zuoyu/ServerComputer/nginx/logs/nginx_error.log crit; #日志位置和日志级别
  7
  8
  9 pid /home/zuoyu/ServerComputer/nginx/nginx.pid;
 10
 11 worker_rlimit_nofile 65535;
 12
 13 events {
 14     #使用epoll模型提高性能
 15     use epoll;
 16     #单个进程最大连接数
 17     worker_connections 65535;
 18 }
 19
 20
 21 http {
 22     #扩展名与文件类型映射表
 23     include       mime.types;
 24     #默认类型
 25     default_type  application/octet-stream;
 26
 27     log_format  main  ‘$remote_addr - $remote_user [$time_local] "$request" ‘
 28                       ‘$status $body_bytes_sent "$http_referer" ‘
 29                       ‘"$http_user_agent" "$http_x_forwarded_for"‘;
 30
 31     client_header_buffer_size 32k;
 32     large_client_header_buffers 4 32k;
 33     client_max_body_size 8m;
 34     types_hash_max_size 2048;
 35     types_hash_bucket_size 128;
 36
 37     sendfile on;
 38     tcp_nopush on;
 39     keepalive_timeout 60;
 40     tcp_nodelay on;
 41     fastcgi_connect_timeout 300;
 42     fastcgi_send_timeout 300;
 43     fastcgi_read_timeout 300;
 44     fastcgi_buffer_size 64k;
 45     fastcgi_buffers 4 64k;
 46     fastcgi_busy_buffers_size 128k;
 47     fastcgi_temp_file_write_size 128k;
 48     # 解压缩传输
 49     gzip on;
 50     gzip_min_length 1k;
 51     gzip_buffers 4 16k;
 52     gzip_http_version 1.0;
 53     gzip_comp_level 2;
 54     gzip_types text/plain application/x-javascript text/css application/xml;
 55     gzip_vary on;
 56
 57     #负载均衡组
 58     #静态服务器组
 59     upstream static.zuoyu.com {
 60         server localhost:81;
 61     }
 62
 63     #动态服务器组
 64     upstream dynamic.zuoyu.com {
 65         server localhost:8080;
 66         # server localhost:8081;
 67         # server localhost:8082;
 68         # server localhost:8083;
 69     }
 70
 71     #配置代理参数
 72     proxy_redirect off;
 73     proxy_set_header HOST $host;
 74     proxy_set_header X-Real-IP $remote_addr;
 75     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 76     # client_max_body_size 10m;
 77     client_body_buffer_size 128k;
 78     proxy_connect_timeout 90;
 79     proxy_send_timeout 90;
 80     proxy_read_timeout 90;
 81     proxy_buffer_size 16k;
 82     proxy_buffers 4 32k;
 83     proxy_busy_buffers_size 64k;
 84     proxy_temp_file_write_size 64k;
 85
 86     #缓存配置
 87     proxy_cache_key ‘$host:$server_port$request_uri‘;
 88     # proxy_temp_file_write_size 64k;
 89     proxy_temp_path /home/zuoyu/ServerComputer/nginx/proxy_temp_path;
 90     proxy_cache_path /home/zuoyu/ServerComputer/nginx/proxy_cache_path levels=1:2 keys_zone=cache_one:200m inactive=5d max_size=1g;
 91     proxy_ignore_headers X-Accel-Expires Expires Cache-Control Set-Cookie;
 92
 93     #静态资源主机
 94     server {
 95         listen 81;
 96         server_name localhost_0;
 97         charset utf8;
 98
 99         location / {
100             root /home/zuoyu/Public/NginxStaticSource/static;
101         }
102     }
103     # 下面是server虚拟主机的配置
104     server {
105         listen 80;#监听端口
106         server_name localhost_1;#域名
107         charset utf8;
108
109         location / {
110             # root   /usr/share/nginx/html;
111             proxy_pass http://dynamic.zuoyu.com;
112             index  index.html index.jsp;
113         }
114
115
116         location ~ .*\.(jsp|do|action)$
117         {
118             index index.jsp;
119             proxy_pass http://dynamic.zuoyu.com;
120
121         }
122
123
124
125         location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|ico|svg)$
126         {
127             #缓存30天
128             expires 30d;
129             proxy_pass http://static.zuoyu.com;
130             proxy_cache cache_one;
131             proxy_cache_valid 200 304 302 5d;
132             proxy_cache_valid any 5d;
133             proxy_cache_key ‘$host:$server_port$request_uri‘;
134             add_header X-Cache ‘$upstream_cache_status from $host‘;
135         }
136
137         location ~ .*\.(ttf|woff|woff2)$
138         {
139             #缓存30天
140             expires 30d;
141             proxy_pass http://static.zuoyu.com;
142             proxy_cache cache_one;
143             proxy_cache_valid 200 304 302 5d;
144             proxy_cache_valid any 5d;
145             proxy_cache_key ‘$host:$server_port$request_uri‘;
146             add_header X-Cache ‘$upstream_cache_status from $host‘;
147         }
148
149         location ~ .*\.(js|css)$
150         {
151             #缓存7天
152             expires 7d;
153             proxy_pass http://static.zuoyu.com;
154             proxy_cache cache_one;
155             proxy_cache_valid 200 304 302 5d;
156             proxy_cache_valid any 5d;
157             proxy_cache_key ‘$host:$server_port$request_uri‘;
158             add_header X-Cache ‘$upstream_cache_status from $host‘;
159         }
160
161         #其他页面反向代理到tomcat容器
162         location ~ .*$ {
163             index index.jsp index.html;
164             proxy_pass http://dynamic.zuoyu.com;
165         }
166         access_log off;
167         error_page   500 502 503 504  /50x.html;
168
169         location = /50x.html {
170             root   /usr/share/nginx/html;
171         }
172     }
173
174
175 }
176         

  

  在这段配置文件中,不仅仅包含了静动态访问的分离,还包括缓存、资源压缩、负载均衡。在这里只分析静动态资源:

  静态资源配置

  以访问图片为例子:

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|ico|svg)$
        {
           root /home/zuoyu/Public/NginxStaticSource/static;
        }

  当你访问虚拟主机 location:80 时,当访问到以上述文件类型时,会去root /home/zuoyu/Public/NginxStaticSource/static/目录下查找,比如你要访问root /home/zuoyu/Public/NginxStaticSource/static/img/background.png这个图片,那么你只需要location:80/img/background.png即可访问到该文件;

  在我的配置中,又建立了一个主机,专门用来配置静态资源路径,这样就避免了换一次静态资源的目录要改好多个地方,只需修改主机路径就可以实现。便可以将上述图片配置修改为

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|ico|svg)$
        {
            proxy_pass http://localhost:81;
        }

  这样便大大提高了灵活性,而且在负载均衡时更加容易实现。注意:必须将静态资源主机配置放在核心主机的上面才有效。

  动态数据配置

  我们就以访问JSP页面、do请求、action请求为例子

location ~ .*\.(jsp|do|action)$
        {
            index index.jsp;
            proxy_pass http://localhost:8080;

        }

  这个配置告诉了Nginx服务器:当有以jsp、do、action为后缀的请求,就将该请求交给localhost:8080;这个主机处理,这个主机的主页是index.jsp,这个就叫反向代理。这里设计到一个概念——代理与反向代理;代理通常需要在客户端配置,将本来要发送的请求转发到代理服务器;而反向代理要配置在服务器上,将本来要发送到本服务器上的请求转发到代理服务器上。

  将所有需要Tomcat应用服务器处理的请求都交给Tomcat,剩下的让Nginx处理就好了,如果需要其他服务器的,再配置上就ok了。

  如此一来,就实现了动静分离。当用户的浏览器加载页面时,那些css文件、js文件、字体样式、图片等等都会由Nginx服务器直接从本地硬盘取出返回给用户浏览器;而用户名等等信息会由nginx交给Tomcat处理后返回给Nginx,Nginx返回到用户浏览器。

  怕什么真理无穷,进一寸有进一寸的欢喜。

  

  

  

原文地址:https://www.cnblogs.com/1214804270hacker/p/9299462.html

时间: 2024-12-06 14:03:20

Nginx与Tomcat实现请求动态数据与请求静态资源的分离的相关文章

【Paddy】如何将物理表分割成动态数据表与静态数据表

前言 一般来说,物理表的增.删.改.查都受到数据量的制约,进而影响了性能. 很多情况下,你所负责的业务关键表中,每日变动的数据库与不变动的数据量比较,相差非常大. 这里我们将变动的数据称为动态数据,不变动的数据称为静态数据. 举个例子,1张1000W的表,每日动态数据只有1W条,999W条的数据都为静态.往往select或者重复改变的数据都在动态数据中.比如订单表. 所以,如果将动态数据库从表中剥离出来,分割两张表,一张动态数据表,一张静态数据表,从数据量的角度来看,性能是不是就会自然提高了?

nginx 与 tomcat 组合搭建web服务

部分内容转自 http://www.cnblogs.com/naaoveGIS/ 1. Web服务 nginx是常用的web服务器,用于获取静态资源,类似的服务器还有apache. tomcat是基于java servlet 的 web 容器,用于获取动态资源. 一般的web服务架构:前端部署nginx,后端部署tomcat.用户访问nginx,静态资源nginx直接返回,动态资源的请求被nginx转发到tomcat,tomcat将处理完的结构返回给nginx,然后到浏览器. 2.Nginx简介

Nginx 与Tomcat 实现动静态分离、负载均衡

一.Nginx简介: Nginx一个高性能的HTTP和反向代理服务器, 具有很高的稳定性和支持热部署.模块扩展也很容易.当遇到访问的峰值,或者有人恶意发起慢速连接时,也很可能会导致服务器物理内存耗尽频繁交换,失去响应,只能重启服务器,Nginx采取了分阶段资源分配技术,处理静态文件和无缓存的反向代理加速,实现了负载均衡和容错,在这样高并发的访问情况下,能经受起高并发的处理. 二.Nginx安装与配置   第一步:下载Nginx 安装包  http://nginx.org/en/download.

Java Web -- Servlet(13)HttpServletRequest详解(获取请求数据、请求分派、请求域)(2)

                                    HttpServletRequest ---------------------------------------------------------------- (4)请求分派 Servlet API中定义了一个RequestDispatcher接口,俗称请求分派器. 它有两个方法 forward(ServletRequest request,ServletResponse response) include(Serv

Ajax在jQuery中的应用(加载异步数据、请求服务器数据)

加载异步数据 jQuery中的load()方法 load(url,[data],[callback]) url:被加载的页面地址 [data]:可选项表示发送到服务器的数据,其格式为 key/value . [callback]:可选项表示加载成功后,返回至加载页的回调函数. 全局函数 getJSON() $.getJSON(url,[data],[callback]) <div class="container col-lg-12"> <div style=&quo

十三 .Flask wtforms组件和选择框动态数据实时更新

一 . wtforms组件     选择框动态数据实时更新 https://www.cnblogs.com/lovershowtime/p/11384494.html 1.wtforms组件使用(登录) 1. 用户登录 当用户登录时候,需要对用户提交的用户名和密码进行多种格式校验.如: 用户不能为空:用户长度必须大于6: 密码不能为空:密码长度必须大于12:密码必须包含 字母.数字.特殊字符等(自定义正则): login.html <!DOCTYPE html> <html lang=&

WebSphere 更新应用后请求静态资源出现 503 错误

系统环境:WebSphere 6.1.0.25 Network Deployment, 有集群,前端用IBM Http Server Plugin 事情是这样的,由于本集群上有多个应用,所以在更新应用时不可以重启App Server.同时,在集群环境中,如果直接更新应用,会自动触发WAS集群中的App Server重启.所以我们更新应用的习惯是,先停止应用,再卸载,然后再部署新的版本. 在这样的应用更新实施之后,出现过两次这样的情况:部署后的新应用,功能都正常,就是样式全丢了.使用Firefox

详谈Apache、Nginx和tomcat的区别以及处理静态页面和动态页面的方式

就目前来说,网站主要分为静态页面和动态页面,纯静态页面的网站已经比较少见了,大型网站一般使用的是静态页面+动态页面的建站技术,还有一部分网站是纯动态页面.负责处理这些页面的软件我们通常称之为web容器,是一种服务程序,负责处理客户端(浏览器)发来的访问请求,如果是静态页面会直接将文件内容呈现给客户端(浏览器),如果是动态页面会将其解析成静态内容之后再呈现给客户端(浏览器). 一.Apache.Nginx和tomcat的区别 ApacheApache HTTP Server(简称Apache)是A

Nginx与Tomcat、Client之间请求的长连接配置不一致问题解决[转]

http://bert82503.iteye.com/blog/2152613 前些天,线上出现“服务端长连接与客户端短连接引起Nginx的Writing.Active连接数过高问题”,这个是由于“服务端使用HTTPs长连接,而客户端使用短连接”引起.这几天,发现Nginx与Tomcat之间也存在同样的问题,原因是两边的相关配置参数不一致引起的.(这是心细活!) 先说说服务为什么使用HTTPs长连接技术?有如下几个原因: 对响应时间要求较高: 服务走的是公网,客户端与服务端的TCP建立的三次握手