Nginx+Tomcat 靜態、動態分離

1、什麼是動靜分離javascript

本文的動靜分離主要是經過nginx+tomcat來實現,其中nginx處理圖片、html等靜態的文件,tomcat處理jsp、do等動態文件。php

2、結構圖css

3、安裝html

一、安裝、配置nginxjava

下載nginx與pcre(若是須要使用正則,須要安裝pcre)node

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

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

安裝pcreweb

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

安裝nginxapache

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

二、安裝、配置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

相關文章
相關標籤/搜索