搭建nginx+tomcat+Java的負載均衡環境

1、簡介: php

Tomcat在高併發環境下處理動態請求時性能很低,而在處理靜態頁面更加脆弱。雖然Tomcat的最新版本支持epoll,可是經過Nginx來處理靜態頁面要比經過Tomcat處理在性能方面好不少。 css

2、下載安裝: html

下載nginx nginx

http://nginx.org/en/download.html web

下載解壓後放到C:\nginx-1.0.4(官網這樣要求的,不知道放其它盤有沒有問題) 正則表達式

啓動nginx.exe,而後在瀏覽器輸入127.0.0.1便可 後端

配置本身的項目測試 瀏覽器

第二環節咱們使用了默認的nginx.conf 。Nginx的配置文件都存於目錄conf文件下,其中nginx.conf是它的主配置文件。 緩存

如下爲我加上註釋並配置的新的虛擬server] tomcat

Java代碼   收藏代碼
  1. #運行用戶  
  2. #user  nobody;  
  3. #開啓進程數 <=CPU數  
  4. worker_processes  1;  
  5. #錯誤日誌保存位置  
  6. #error_log  logs/error.log;  
  7. #error_log  logs/error.log  notice;  
  8. #error_log  logs/error.log  info;  
  9. #進程號保存文件  
  10. #pid        logs/nginx.pid;  
  11.    
  12. #等待事件  
  13. events {  
  14.     #Linux下打開提升性能  
  15.     #use epoll;  
  16.     #每一個進程最大鏈接數(最大鏈接=鏈接數x進程數)  
  17.     worker_connections  1024;  
  18. }  
  19.    
  20.    
  21. http {  
  22.     #文件擴展名與文件類型映射表  
  23.     include       mime.types;  
  24.     #默認文件類型  
  25.     default_type  application/octet-stream;  
  26.     #日誌文件輸出格式 這個位置相於全局設置  
  27.     #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '  
  28.     #                  '$status $body_bytes_sent "$http_referer" '  
  29.     #                  '"$http_user_agent" "$http_x_forwarded_for"';  
  30.        
  31.     #請求日誌保存位置  
  32.     #access_log  logs/access.log  main;  
  33.        
  34.     #設定請求緩衝  
  35.     client_header_buffer_size 1k;  
  36.     large_client_header_buffers 4 4k;  
  37.    
  38.     #打開發送文件  
  39.     sendfile        on;  
  40.     #tcp_nopush     on;  
  41.    
  42.     #keepalive_timeout  0;  
  43.     keepalive_timeout  65;  
  44.        
  45.     #客戶端上傳文件大小控制  
  46.     client_max_body_size 8m;  
  47.        
  48.     #打開gzip壓縮  
  49.     #gzip  on;  
  50.        
  51.     #設定負載均衡的服務器列表  
  52.     #upstream mysvr {  
  53.     #    #weigth參數表示權值,權值越高被分配到的概率越大  
  54.     #    #本機上的Squid開啓3128端口  
  55.     #    #server 192.168.8.1:3128 weight=5;  
  56.     #    #server 192.168.8.2:80 weight=1;  
  57.     #    #server 192.168.8.3:80 weight=6;  
  58.     #}  
  59.    
  60.     #第一個虛擬主機  
  61.     server {  
  62.         #監聽IP端口  
  63.         listen       80;  
  64.         #主機名  
  65.         server_name  localhost;  
  66.         #root    
  67.            
  68.         #設置字符集  
  69.         #charset koi8-r;  
  70.         #本虛擬server的訪問日誌 至關於局部變量  
  71.         #access_log  logs/host.access.log  main;  
  72.         #日誌文件輸出格式  
  73.         #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '  
  74.         #                  '$status $body_bytes_sent "$http_referer" '  
  75.         #                  '"$http_user_agent" "$http_x_forwarded_for"';  
  76.            
  77.         location / {  
  78.             root   html;  
  79.             index  index.html index.htm;  
  80.         }  
  81.            
  82.         #靜態文件緩存時間設置  
  83.         #location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)${           
  84.         #    expires 30d;  
  85.         #}  
  86.            
  87.         #靜態文件緩存時間設置  
  88.         #location ~ .*\.(js|css)?${           
  89.         #    expires 1h;  
  90.         #}  
  91.            
  92.         #對本server"/"啓用負載均衡  
  93.         #location / {  
  94.         #    proxy_pass http://mysvr;  
  95.         #    proxy_redirect off;  
  96.         #    proxy_set_header Host $host;  
  97.         #    proxy_set_header X-Real-IP $remote_addr;  
  98.         #    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
  99.         #    client_max_body_size 10m;  
  100.         #    client_body_buffer_size 128k;  
  101.         #    proxy_connect_timeout 90;  
  102.         #    proxy_send_timeout 90;  
  103.         #    proxy_read_timeout 90;  
  104.         #    proxy_buffer_size 4k;  
  105.         #    proxy_buffers 4 32k;  
  106.         #    proxy_busy_buffers_size 64k;  
  107.         #    proxy_temp_file_write_size 64k;  
  108.         #}  
  109.            
  110.         #設定查看Nginx狀態的地址  
  111.         #location /NginxStatus {  
  112.         #    stub_status on;  
  113.         #    access_log on;  
  114.         #    auth_basic 「NginxStatus」;  
  115.         #    auth_basic_user_file conf/htpasswd;  
  116.         #}  
  117.    
  118.    
  119.    
  120.         #error_page  404              /404.html;  
  121.    
  122.         # redirect server error pages to the static page /50x.html  
  123.         #  
  124.         error_page   500 502 503 504  /50x.html;  
  125.         location = /50x.html {  
  126.             root   html;  
  127.         }  
  128.    
  129.         # proxy the PHP scripts to Apache listening on 127.0.0.1:80  
  130.         #  
  131.         #location ~ \.php$ {  
  132.         #    proxy_pass   http://127.0.0.1;  
  133.         #}  
  134.    
  135.         # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000  
  136.         #  
  137.         #location ~ \.php$ {  
  138.         #    root           html;  
  139.         #    fastcgi_pass   127.0.0.1:9000;  
  140.         #    fastcgi_index  index.php;  
  141.         #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;  
  142.         #    include        fastcgi_params;  
  143.         #}  
  144.    
  145.         # deny access to .htaccess files, if Apache's document root  
  146.         # concurs with nginx's one  
  147.         #  
  148.         #location ~ /\.ht {  
  149.         #    deny  all;  
  150.         #}  
  151.     }  
  152.    
  153.    
  154.     # another virtual host using mix of IP-, name-, and port-based configuration      
  155.     server {  
  156.         #多監聽         
  157.         listen       localhost:8666;  
  158.         #主機名  
  159.         server_name  LIULJ2576;  
  160.         #WEB文件路徑  
  161.         root         E:/Portal;  
  162.         #默認首頁  
  163.         index        HomePage.html;          
  164.         #location / {  
  165.         #    #這裏至關於局部變量  
  166.         #    root   E:/Portal;  
  167.         #    index  HomePage.html;  
  168.         #}  
  169.     }  
  170.    
  171.    
  172.     # HTTPS server HTTPS SSL加密服務器  
  173.     #  
  174.     #server {  
  175.     #    listen       443;  
  176.     #    server_name  localhost;  
  177.    
  178.     #    ssl                  on;  
  179.     #    ssl_certificate      cert.pem;  
  180.     #    ssl_certificate_key  cert.key;  
  181.    
  182.     #    ssl_session_timeout  5m;  
  183.    
  184.     #    ssl_protocols  SSLv2 SSLv3 TLSv1;  
  185.     #    ssl_ciphers  ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;  
  186.     #    ssl_prefer_server_ciphers   on;  
  187.    
  188.     #    location / {  
  189.     #        root   html;  
  190.     #        index  index.html index.htm;  
  191.     #    }  
  192.     #}  
  193.    
  194. }  

 #號爲註釋內容,咱們在cmd下運行nginx

啓動成功,出錯的話,能夠查詢日誌(日誌路徑是配置文件指定的,你能夠修改存到其它位置)

訪問一下第二個server 配置的localhost:8666地址,結果出現

 

3、Nginx能夠經過如下兩種方式來實現與Tomcat的耦合:

將靜態頁面請求交給Nginx,動態請求交給後端Tomcat處理。

將全部請求都交給後端的Tomcat服務器處理,同時利用Nginx自身的負載均衡功能進行多臺Tomcat服務器的負載均衡。

下面經過兩個配置實例分別講述這兩種實現

1、動態頁面和靜態頁面分離的實例

這裏假定Tomcat服務器的IP地址爲192.168.12.130,同時Tomcat服務器開放的服務器端口爲8080。Nginx相關配置代碼以下:

Java代碼   收藏代碼
  1. server {   
  2.       listen 80;    
  3.       server_name www.ixdba.net;    
  4.       root /web/www/html;    
  5.     
  6. location /img/ {    
  7.       alias /web/www/html/img/;    
  8. }    
  9.     
  10. location ~ (\.jsp)|(\.do)$ {    
  11.      proxy_pass http://192.168.12.130:8080;    
  12.      proxy_redirect off;    
  13.      proxy_set_header Host $host;    
  14.      proxy_set_header X-Real-IP $remote_addr;    
  15.      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;    
  16.      client_max_body_size 10m;    
  17.      client_body_buffer_size 128k;    
  18.      proxy_connect_timeout 90;    
  19.      proxy_send_timeout 90;    
  20.      proxy_read_timeout 90;    
  21.      proxy_buffer_size 4k;    
  22.      proxy_buffers 4 32k;    
  23.      proxy_busy_buffers_size 64k;    
  24.      proxy_temp_file_write_size 64k;    
  25. }    
  26.     
  27. }  

 在這個實例中,首先定義了一個虛擬主機www.ixdba.net,而後經過location指令將/web/www/html/img/目錄下的靜態文件交給Nginx來完成。最後一個location指令將全部以.jsp、.do結尾的文件都交給Tomcat服務器的8080端口來處理,即http://192.168.12.130:8080

須要特別注意的是,在location指令中使用正則表達式後,proxy_pass後面的代理路徑不能含有地址連接,也就是不能寫成http://192.168.12.130:8080/,或者相似http://192.168.12.130:8080/jsp的形式。在location指令不使用正則表達式時,沒有此限制。

二、多個tomcat負載均衡的實例

這裏假定有3臺Tomcat服務器,分別開放不一樣的端口,地址以下:

?
1
2
3
192.168.12.131:8000 
192.168.12.132:8080 
192.168.12.133:8090

Nginx的相關配置代碼以下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
upstream mytomcats { 
      server192.168.12.131:8000; 
      server192.168.12.132:8080; 
      server192.168.12.133:8090; 
  
server { 
      listen80; 
      server_name www.ixdba.net; 
  
location ~* \.(jpg|gif|png|swf|flv|wma|wmv|asf|mp3|mmf|zip|rar)$ { 
       root /web/www/html/; 
  
location / { 
          proxy_pass http://mytomcats; 
          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_timeout90; 
          proxy_send_timeout90; 
          proxy_read_timeout90; 
          proxy_buffer_size 4k; 
          proxy_buffers432k; 
          proxy_busy_buffers_size 64k; 
          proxy_temp_file_write_size 64k; 
相關文章
相關標籤/搜索