文档章节

Nginx+Tomcat 静态、动态分离

AndyXi
 AndyXi
发布于 2015/09/01 10:23
字数 871
阅读 20
收藏 0

一、什么是动静分离

本文的动静分离主要是通过nginx+tomcat来实现,其中nginx处理图片、html等静态的文件,tomcat处理jsp、do等动态文件。

二、结构图

三、安装

1、安装、配置nginx

下载nginx与pcre(如果需要使用正则,需要安装pcre)

wget http://blog.s135.com/soft/linux/nginx_php/nginx/nginx-0.8.46.tar.gz

wget http://blog.s135.com/soft/linux/nginx_php/pcre/pcre-8.10.tar.gz

安装pcre


  
  
  1. tar zxvf pcre-8.10.tar.gz  
  2. cd pcre-8.10/  
  3. ./configure  
  4. make   
  5. make install   cd ..

安装nginx


  
  
  1. tar zxvf nginx-0.8.46.tar.gz  
  2. cd nginx-0.8.46/  
  3. ./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module  
  4. make    
  5. make install  

nginx.conf配置


  
  
  1. user  www www;  
  2.  
  3. worker_processes 8;  
  4.  
  5. error_log  /usr/local/nginx/logs/nginx_error.log  crit;  
  6.  
  7. pid        /usr/local/nginx/nginx.pid;  
  8.  
  9. worker_rlimit_nofile 65535;  
  10.  
  11. events   
  12. {  
  13.   use epoll;  
  14.   worker_connections 65535;  
  15. }  
  16.  
  17. http   
  18. {  
  19.   include       mime.types;  
  20.   default_type  application/octet-stream;  
  21.  
  22.   #charset  gb2312;  
  23.         
  24.   server_names_hash_bucket_size 128;  
  25.   client_header_buffer_size 32k;  
  26.   large_client_header_buffers 4 32k;  
  27.   client_max_body_size 8m;  
  28.         
  29.   sendfile on;  
  30.   tcp_nopush     on;  
  31.  
  32.   keepalive_timeout 60;  
  33.  
  34.   tcp_nodelay on;  
  35.  
  36.   fastcgi_connect_timeout 300;  
  37.   fastcgi_send_timeout 300;  
  38.   fastcgi_read_timeout 300;  
  39.   fastcgi_buffer_size 64k;  
  40.   fastcgi_buffers 4 64k;  
  41.   fastcgi_busy_buffers_size 128k;  
  42.   fastcgi_temp_file_write_size 128k;  
  43.  
  44.   gzip on;  
  45.   gzip_min_length  1k;  
  46.   gzip_buffers     4 16k;  
  47.   gzip_http_version 1.0;  
  48.   gzip_comp_level 2;  
  49.   gzip_types       text/plain application/x-javascript text/css application/xml;  
  50.   gzip_vary on;  
  51.  
  52.   #limit_zone  crawler  $binary_remote_addr  10m;  
  53.  
  54.   server  
  55.   {  
  56.     listen       80;  
  57.     server_name  test1.dl.com;              ####test1.dl.com的ip为10.1.88.176  
  58.     index index.html index.htm index.php;  
  59.     root  /usr/local/nginx/html;  
  60.  
  61.     #limit_conn   crawler  20;      
  62.                                
  63.     location ~ .*\.(php|php5)?$  
  64.     {        
  65.       #fastcgi_pass  unix:/tmp/php-cgi.sock;  
  66.       fastcgi_pass  127.0.0.1:9000;  
  67.       fastcgi_index index.php;  
  68.       include fastcgi.conf;  
  69.    }  
  70.       
  71.     location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$              ###所以的静态文件人gif、jpg等都在本地打开,存放的目录为/usr/local/nginx/html,保存时间为30天  
  72.     {  
  73.         root         /usr/local/nginx/html;   
  74.     expires      30d;  
  75.     }  
  76.     location ~ (\.jsp)|(\.do)$                              ###所以jsp、do的动态请求都交给后面的tomcat处理  
  77.     {  
  78.     proxy_pass http://10.1.88.168:8080;  
  79.     proxy_redirect off;  
  80.     proxy_set_header HOST $host;  
  81.     proxy_set_header X-Real-IP $remote_addr;  
  82.     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
  83.     client_max_body_size 10m;  
  84.     client_body_buffer_size 128k;  
  85.     proxy_connect_timeout 90;  
  86.     proxy_send_timeout 90;  
  87.     proxy_read_timeout 90;  
  88.     proxy_buffer_size 4k;  
  89.     proxy_buffers 4 32k;  
  90.     proxy_busy_buffers_size 64k;  
  91.     proxy_temp_file_write_size 64k;  
  92.      }  
  93.     location ~ .*\.(js|css)?$  
  94.     {  
  95.       expires      1h;  
  96.     }      
  97.  
  98.     log_format  access  '$remote_addr - $remote_user [$time_local] "$request" '  
  99.               '$status $body_bytes_sent "$http_referer" '  
  100.               '"$http_user_agent" $http_x_forwarded_for';  
  101.     access_log  /usr/local/nginx/logs/access.log  access;  
  102.  
  103. }  
  104.   server  
  105.   {  
  106.     listen  80;  
  107.     server_name  status.test1.dl.com;  
  108.  
  109.     location / {  
  110.     stub_status on;  
  111.     access_log   off;  
  112.     }  
  113.   }  
  114. }  

2、安装、配置tomcat

先安装jdk


  
  
  1. wget http://download.oracle.com/otn-pub/java/jdk/7u3-b04/jdk-7u3-linux-x64.rpm  
  2. chmod 755 jdk-7u3-linux-x64.rpm  
  3. rpm -ivh jdk-7u3-linux-x64.rpm  
在/etc/profile里设置环境变量

  
  
  1. JAVA_HOME=/usr/java/jdk1.7.0  
  2. CLASSPATH=$JAVA_HOME/lib:$JAVA_HOME/jre/lib   
  3. PATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/jre/bin   
  4. export PATH CLASSPATH JAVA_HOME   
然后在source /etc/profile使这个改变生效

安装tomcat


  
  
  1. wget http://mirror.bjtu.edu.cn/apache/tomcat/tomcat-7/v7.0.25/bin/apache-tomcat-7.0.25.tar.gz  
  2. tar zxvf apache-tomcat-7.0.25.tar.gz  
  3. cp -R apache-tomcat-7.0.25 /usr/local/tomcat  

启动tomcat


  
  
  1. /usr/local/tomcat/bin/startup.sh 
之后打开http://localhost:8080就能看到tomcat的默认界面了
下面我们来修改tomcat的首页
我在$tomcat/webapps/下建了个html目录作为我网站的默认目录,在html中有一个index.html文件,该文件要作为我网站的默认主页。
首先,修改$tomcat/conf/server.xml文件。
在server.xml文件中,有一段如下:
 

  
  
  1. ……  
  2. <engine name="Catalina" defaultHost="localhost"> 
  3. <host name="localhost" appBase="webapps" 
  4. unpackWARs="true" autoDeploy="true" 
  5. xmlValidation="false" xmlNamespaceAware="false"> 
  6. ……  
  7. <host> 
  8. </engine> 
  9. ……  

在<host></host>标签之间添加上:
 


  
  
  1. <Context path="" docBase="html" debug="0" reloadable="true" /> 
path是说明虚拟目录的名字,如果你要只输入ip地址就显示主页,则该键值留为空;

docBase是虚拟目录的路径,它默认的是$tomcat/webapps/ROOT目录,现在我在webapps目录下建了一个html目录,让该目录作为我的默认目录。

debug和reloadable一般都分别设置成0和true。

然后,修改$tomcat/conf/web.xml文件。
在web.xml文件中,有一段如下:


  
  
  1. <welcome-file-list> 
  2. <welcome-file>index.html</welcome-file> 
  3. <welcome-file>index.htm</welcome-file> 
  4. <welcome-file>index.jsp</welcome-file> 
  5. </welcome-file-list> 

在<welcome-file-list>与<welcome-file>index.html</welcome-file>之间添加上:


  
  
  1. <welcome-file>html</welcome-file> 
修改完成之后,重启tomcat即可看到index.html里的内容
tomcat服务器的ip为10.1.88.168

在test4建立test.jsp、test1.do文本,内容如下

tomcat的首页内容

test.jsp内容

test1.do内容

nginx的首页内容

在nginx里查看动态请求

nginx处理test1.do

© 著作权归作者所有

AndyXi
粉丝 1
博文 31
码字总数 75190
作品 0
深圳
程序员
私信 提问
Nginx+Tomcat动静分离及Nginx优化

目的:nginx处理用户请求的静态页面,tomcat处理用户请求jsp页面,来实现动态分离,nginx处理静态页面效率远高于tomcat,这样一来就能更好的提高并发,处理性能。 准备软件: 下载jdk1.7:h...

vane_
2014/04/26
22.5K
1
Nginx加多个tomcat实现负载均衡,动静分离

一:Nginx+Tomcat的动静分离 所谓动静分离就是通过nginx(或apache等)来处理用户端请求的图片、html等静态的文件,tomcat(或weblogic)处理jsp、do等动态文件,从而达到动静页面访问时通过...

fighting-cluber
2014/03/16
8.9K
0
Nginx + Tomcat + Ngx_cache_purge 实现高效反向代理

Nginx处理用户请求的静态页面,tomcat处理用户请求jsp页面,来实现动态分离,前端nginx反向代理后端nginx+tomcat集群,实现负载均衡,这样一来就能更好的提高并发,处理性能,并隐藏后端,提...

静夜听风
2015/04/02
1K
6
nginx+tomcat实现动静分离

nginx+tomcat实现动静分离 本文设计的动静分离结构 在本文中,我们将静态资源放在 A 主机的一个目录上,将动态程序放在 B 主机上,同时在 A 上安装 Nginx 并且在 B 上安装 Tomcat。配置 Ngin...

linjin200
2018/11/01
81
0
Nginx+Tomcat实现动静分离

转载于 http://dl528888.blog.51cto.com/2382721/804596 一、什么是动静分离 本文的动静分离主要是通过nginx+tomcat来实现,其中nginx处理图片、html等静态的文件,tomcat处理jsp、do等动态文...

tanp398
2018/06/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

CQRS与AXON

CQRS 看了蛮多文章,只会CRUD,却不懂CQRS,CQRS是遵循DDD思想而产生的一种模式,Command and Query Responsibility Segregation 命令与查询隔离。查询就直接通过正常的模式service调dao层。...

无极之岚
11分钟前
2
0
OSChina 周三乱弹 —— 欢迎你来做产品经理

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @巴拉迪维 :10多次劲歌金曲获奖,更多叱咤歌坛排名,黎明才应该是四大天王之首,只可惜拍的电影太少。单曲循环一个多月的歌,力荐 《无名份的...

小小编辑
26分钟前
27
2
500行代码,教你用python写个微信飞机大战

这几天在重温微信小游戏的飞机大战,玩着玩着就在思考人生了,这飞机大战怎么就可以做的那么好,操作简单,简单上手。 帮助蹲厕族、YP族、饭圈女孩在无聊之余可以有一样东西让他们振作起来!...

上海小胖
今天
8
0
关于AsyncTask的onPostExcute方法是否会在Activity重建过程中调用的问题

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接:https://blog.csdn.net/XG1057415595/article/details/86774575 假设下面一种情况...

shzwork
今天
7
0
object 类中有哪些方法?

getClass(): 获取运行时类的对象 equals():判断其他对象是否与此对象相等 hashcode():返回该对象的哈希码值 toString():返回该对象的字符串表示 clone(): 创建并返此对象的一个副本 wait...

happywe
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部