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

一、什么是动静分离

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

二、结构图

Nginx+Tomcat实现动静分离_第1张图片

三、安装

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. ……  

标签之间添加上:
 

   
   
   
   
  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.htmlwelcome-file> 
  3. <welcome-file>index.htmwelcome-file> 
  4. <welcome-file>index.jspwelcome-file> 
  5. welcome-file-list> 

index.html之间添加上:

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

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

tomcat的首页内容

Nginx+Tomcat实现动静分离_第2张图片

test.jsp内容

Nginx+Tomcat实现动静分离_第3张图片

test1.do内容

Nginx+Tomcat实现动静分离_第4张图片

nginx的首页内容

Nginx+Tomcat实现动静分离_第5张图片

在nginx里查看动态请求

Nginx+Tomcat实现动静分离_第6张图片

nginx处理test1.do

Nginx+Tomcat实现动静分离_第7张图片

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