欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

Nginx + Tomcat实现请求动态数据和请求静态资源的分离详解

程序员文章站 2022-07-09 17:31:54
前言 上篇博客说明了nginx在应用架构中的作用,以及负载均衡的思路。这篇实践一下其中的访问静态资源与访问动态资源的操作。 一、认识访问静态资源与访问动态资源的区别...

前言

上篇博客说明了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;

先来一个全部配置:

# user www www;
user root root;

worker_processes 2; #设置值和cpu核心数一致

error_log /home/zuoyu/servercomputer/nginx/logs/nginx_error.log crit; #日志位置和日志级别


pid /home/zuoyu/servercomputer/nginx/nginx.pid;

worker_rlimit_nofile 65535;

events {
 #使用epoll模型提高性能
 use epoll;
 #单个进程最大连接数
 worker_connections 65535;
}


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"';

 client_header_buffer_size 32k;
 large_client_header_buffers 4 32k;
 client_max_body_size 8m;
 types_hash_max_size 2048;
 types_hash_bucket_size 128;
 
 sendfile on;
 tcp_nopush on;
 keepalive_timeout 60;
 tcp_nodelay on;
 fastcgi_connect_timeout 300;
 fastcgi_send_timeout 300;
 fastcgi_read_timeout 300;
 fastcgi_buffer_size 64k;
 fastcgi_buffers 4 64k;
 fastcgi_busy_buffers_size 128k;
 fastcgi_temp_file_write_size 128k;
 # 解压缩传输
 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-javascript text/css application/xml;
 gzip_vary on;

 #负载均衡组
 #静态服务器组
 upstream static.zuoyu.com {
 server localhost:81;
 }

 #动态服务器组
 upstream dynamic.zuoyu.com {
 server localhost:8080;
 # server localhost:8081;
 # server localhost:8082;
 # server localhost:8083;
 }

 #配置代理参数
 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;
 # client_max_body_size 10m;
 client_body_buffer_size 128k;
 proxy_connect_timeout 90;
 proxy_send_timeout 90;
 proxy_read_timeout 90;
 proxy_buffer_size 16k;
 proxy_buffers 4 32k;
 proxy_busy_buffers_size 64k;
 proxy_temp_file_write_size 64k;
 
 #缓存配置
 proxy_cache_key '$host:$server_port$request_uri';
 # proxy_temp_file_write_size 64k;
 proxy_temp_path /home/zuoyu/servercomputer/nginx/proxy_temp_path;
 proxy_cache_path /home/zuoyu/servercomputer/nginx/proxy_cache_path levels=1:2 keys_zone=cache_one:200m inactive=5d max_size=1g;
 proxy_ignore_headers x-accel-expires expires cache-control set-cookie;

 #静态资源主机
 server {
 listen 81;
 server_name localhost_0;
 charset utf8;

 location / {
  root /home/zuoyu/public/nginxstaticsource/static;
 }
 }
 # 下面是server虚拟主机的配置
 server {
 listen 80;#监听端口
 server_name localhost_1;#域名
 charset utf8;

 location / {
  # root /usr/share/nginx/html;
  proxy_pass http://dynamic.zuoyu.com;
  index index.html index.jsp;
 }


 location ~ .*\.(jsp|do|action)$
 {
  index index.jsp;
  proxy_pass http://dynamic.zuoyu.com;
  
 }

 

 location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|ico|svg)$
 {
  #缓存30天
  expires 30d;
  proxy_pass http://static.zuoyu.com;
  proxy_cache cache_one;
  proxy_cache_valid 200 304 302 5d;
  proxy_cache_valid any 5d;
  proxy_cache_key '$host:$server_port$request_uri';
  add_header x-cache '$upstream_cache_status from $host';
 }

 location ~ .*\.(ttf|woff|woff2)$
 {
  #缓存30天
  expires 30d;
  proxy_pass http://static.zuoyu.com;
  proxy_cache cache_one;
  proxy_cache_valid 200 304 302 5d;
  proxy_cache_valid any 5d;
  proxy_cache_key '$host:$server_port$request_uri';
  add_header x-cache '$upstream_cache_status from $host';
 }

 location ~ .*\.(js|css)$
 {
  #缓存7天
  expires 7d;
  proxy_pass http://static.zuoyu.com;
  proxy_cache cache_one;
  proxy_cache_valid 200 304 302 5d;
  proxy_cache_valid any 5d;
  proxy_cache_key '$host:$server_port$request_uri';
  add_header x-cache '$upstream_cache_status from $host';
 }

 #其他页面反向代理到tomcat容器
 location ~ .*$ {
  index index.jsp index.html;
  proxy_pass http://dynamic.zuoyu.com;
 }
 access_log off; 
 error_page 500 502 503 504 /50x.html;

 location = /50x.html {
  root /usr/share/nginx/html;
 }
 } 
}

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

静态资源配置

以访问图片为例子:

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返回到用户浏览器。

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。