Nginx+Tomcat实现动静分离

简介:

最近公司的项目都完成了,工作很清闲,处理每天的日常巡检工作外,我还整理了一下以前学习的笔记,现在把我的笔记share给大家。

一、什么是动静分离

本文的动静分离主要是通过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

现在nginx+tomcat就实现了动静分离技术,如果大家还有什么疑问,请联系我,我会及时的帮忙解答。



 本文转自 dl528888 51CTO博客,原文链接:http://blog.51cto.com/dl528888/804596,如需转载请自行联系原作者




相关文章
|
27天前
|
运维 前端开发 应用服务中间件
LNMP详解(八)——Nginx动静分离实战配置
LNMP详解(八)——Nginx动静分离实战配置
28 0
|
2月前
|
缓存 前端开发 JavaScript
tomcat核心技术+Nginx性能调优技术
而Tomcat的基本配置,每个配置项也基本上对应了Tomcat的组件结构,如果要用一张图来形象展现一下Tomcat组成的话
37 1
|
2月前
|
Java 应用服务中间件 Apache
简介Nginx,Tomcat和 Apache
简介Nginx,Tomcat和 Apache
简介Nginx,Tomcat和 Apache
|
3月前
|
负载均衡 应用服务中间件 nginx
百度搜索:蓝易云【Nginx和tomcat实现负载均衡教程】
至此,你已经成功地使用Nginx和Tomcat实现了负载均衡。Nginx将根据配置的负载均衡策略将客户端请求分发到多个Tomcat服务器上,以提高系统的性能和可用性。请注意,在实际生产环境中,还需要进行其他配置和优化,如健康检查、会话保持等,以满足具体的需求。
34 0
|
3月前
|
负载均衡 安全 前端开发
百度搜索:蓝易云【Nginx与Tomcat负载均衡-动静分离教程】
这些是将Nginx与Tomcat结合使用实现负载均衡和动静分离的基本步骤。根据您的需求和具体环境,可能还需要进行其他配置和调整。请确保在进行任何与网络连接和安全相关的操作之前,详细了解您的网络环境和安全需求,并采取适当的安全措施。
49 1
|
4月前
|
负载均衡 前端开发 应用服务中间件
【Linux】Nginx安装使用负载均衡及动静分离(前后端项目部署),前端项目打包
【Linux】Nginx安装使用负载均衡及动静分离(前后端项目部署),前端项目打包
381 0
|
3月前
|
缓存 应用服务中间件 nginx
【Nginx】动静分离
【1月更文挑战第25天】【Nginx】动静分离
|
4月前
|
负载均衡 前端开发 应用服务中间件
百度搜索:蓝易云【Nginx使用之反向代理、负载均衡、动静分离教程。】
通过这样的配置,Nginx将根据请求的URL路径选择是将请求转发到后端服务器还是直接返回静态资源文件。
139 0
|
4月前
|
负载均衡 安全 应用服务中间件
Nginx + Tomcat+HTTP/HTTPS实现负载均衡实例
Nginx + Tomcat+HTTP/HTTPS实现负载均衡实例
179 0
|
4月前
|
负载均衡 算法 应用服务中间件
Nginx+Tomcat实现反向代理与负载均衡入门
Nginx+Tomcat实现反向代理与负载均衡入门
184 0