Nginx+tomcat 实现负载均衡和动静分离

转载于:http://blog.csdn.net/Yoara/article/details/41803153


 怎么下载和安装nginx/tomcat就不说了,谈谈在刚开始配置时最容易让人模糊的地方。


    1.配置动静分离和负载均衡,注意,upstram、server都是在http{}下面的。

upstream t1.test.com {
server 192.168.235.1:8080 weight=1 max_fails=2 fail_timeout=30s; 
}

    其中,红色标注定义的服务器组的名字,后续通过改名字制定服务器组。

server {
listen       80;
#server 
server_name  t1.test.com;


location / {
proxy_connect_timeout   3;
proxy_send_timeout      30;
proxy_read_timeout      30;
proxy_pass http://t1.test.com;
}


#配置Nginx动静分离   
location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ {
root /data/www;
#expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力.
expires 3d;
}
}

    特别注意,蓝色标注的是指域名,就是通过访问http://t1.test.com   将使用该server定义。后面红色标注,指的是使用upstream中定义的服务器组。这样,访问http://t1.test.com域名的所有请求都会被server   t1.test.com处理。


    2.理解了upstream的使用方法,负载均衡就不是问题了,weight表示权重,max_fails=2 fail_timeout=30s这两个参数是指,30s内请求失败2次就不会再访问该server了。fail_timeout时间过后才继续访问,这是容错的一种处理,服务器如果恢复了,还是能继续使用。完整的配置如下


[html] view plain copy 

  1. upstream t1.test.com {  

  2.     server 192.168.235.1:8080 weight=1 max_fails=2 fail_timeout=30s;   

  3. }  

  4. upstream t2.test.com {  

  5.     server 192.168.235.1:8081 weight=1 max_fails=2 fail_timeout=30s;     

  6. }  

  7. upstream all.test.com {  

  8.     server 192.168.235.1:8080 weight=1 max_fails=2 fail_timeout=30s;  

  9.     server 192.168.235.1:8081 weight=1 max_fails=2 fail_timeout=30s;     

  10. }  

  11. server {  

  12.     listen       80;  

  13.     #server   

  14.     server_name  t1.test.com;  

  15.   

  16.     location / {  

  17.         proxy_connect_timeout   3;  

  18.         proxy_send_timeout      30;  

  19.         proxy_read_timeout      30;  

  20.         proxy_pass http://t1.test.com;  

  21.     }  

  22.   

  23.     #配置Nginx动静分离     

  24.     location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ {  

  25.         root /data/www;  

  26.         #expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力.  

  27.         expires 3d;  

  28.     }  

  29. }  

  30. server {  

  31.     listen       80;  

  32.     #server   

  33.     server_name  t2.test.com;  

  34.   

  35.     location / {  

  36.         proxy_connect_timeout   3;  

  37.         proxy_send_timeout      30;  

  38.         proxy_read_timeout      30;  

  39.         proxy_pass http://t2.test.com;  

  40.     }  

  41.   

  42.     #配置Nginx动静分离     

  43.     location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ {  

  44.         root /data/www;  

  45.         #expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力.  

  46.         expires 3d;  

  47.     }  

  48. }  

  49. server {  

  50.     listen       80;  

  51.     #server   

  52.     server_name  all.test.com;  

  53.   

  54.     location / {  

  55.         proxy_connect_timeout   3;  

  56.         proxy_send_timeout      30;  

  57.         proxy_read_timeout      30;  

  58.         proxy_pass http://all.test.com;  

  59.     }  

  60.   

  61.     #配置Nginx动静分离     

  62.     location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ {  

  63.         root /data/www;  

  64.         #expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力.  

  65.         expires 3d;  

  66.     }  


你可能感兴趣的:(server,服务器,listen)