在windows下作nginx负载均衡测试。

nginx的配置文件如下:

worker_processes  1;

events {

worker_connections  1024;

}

http {

include      
mime.types;

default_type  application/octet-stream;

upstream localhost {

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

server 127.0.0.1:8081  weight=1 max_fails=2
fail_timeout=30s;

}

sendfile       
on;

keepalive_timeout  65;

server
{

listen      
80;

server_name  localhost;

listen
80;

server_name
localhost;

location
/{

proxy_pass
http://localhost;

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Forwarded-For
$proxy_add_x_forwarded_for;

}

error_page   500 502 503
504  /50x.html;

location = /50x.html {

root   html;

}

}

}

遇到这个问题,搜索网络, 发现网上也有人遇到同样的问题, 问题描述如下:

用了nginx负载均衡后,在两台tomcat正常运行的情况下,访问http://localhost
速度非常迅速,通过测试程序也可以看出是得到的负载均衡的效果,但是我们试验性的把其中一台tomcat(server
localhost:8080)关闭后,再查看http://localhost,发现反应呈现了一半反映时间快,一半反映时间非常非常慢的情况,但是最
后都能得到正确结果。

然后我又把关闭的那吧tomcat实例恢复,此时再访问http://localhost,又可以很快的访问,负载均衡也运行正常了!郁闷!

分析怀疑可能是nginx将一半的左右的请求仍然发到了宕掉的tomcat实例上了,然后由于转发到宕掉的tomcat没有反映,nginx又重新分发到其它实例上处理。

但是这个时间也太长了。当有一台宕机后,访问http://localhost有时候会现了大概30s左右的响应时间,非常郁闷!

增加这么几个参数:

proxy_connect_timeout  
300;

proxy_send_timeout     
300;

proxy_read_timeout     
300;

问题解决,主要是proxy_connect_timeout  
这个参数, 这个参数是连接的超时时间。 我设置成1,表示是1秒后超时会连接到另外一台服务器。

现在贴出NGINX的配置如下,供后来人参考:

#user  nobody;

worker_processes  1;

#error_log  logs/error.log;

#error_log  logs/error.log 
notice;

#error_log  logs/error.log 
info;

#pid       
logs/nginx.pid;

events {

worker_connections  1024;

}

http {

include      
mime.types;

default_type  application/octet-stream;

upstream localhost {

#ip_hash;

server 127.0.0.1:8081;

server 127.0.0.1:8080;

}

#log_format  main  '$remote_addr
- $remote_user [$time_local] "$request" '

#                 
'$status $body_bytes_sent "$http_referer" '

#                 
'"$http_user_agent" "$http_x_forwarded_for"';

#access_log  logs/access.log 
main;

sendfile       
on;

#tcp_nopush    
on;

#keepalive_timeout  0;

keepalive_timeout  65;

#gzip  on;

server
{

listen      
80;

server_name  localhost;

listen
80;

server_name
localhost;

location
/{

proxy_pass
http://localhost;

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Forwarded-For
$proxy_add_x_forwarded_for;


   
proxy_connect_timeout      
1;

proxy_read_timeout         
1;

proxy_send_timeout         
1;

}

#charset koi8-r;

#access_log 
logs/host.access.log  main;

#error_page 
404             
/404.html;

# redirect server error pages to the static page
/50x.html

#

error_page   500 502 503
504  /50x.html;

location = /50x.html {

root   html;

}

# proxy the PHP scripts to Apache listening on
127.0.0.1:80

#

#location ~ \.php$ {

#   
proxy_pass  
http://127.0.0.1;

#}

# pass the PHP scripts to FastCGI server listening on
127.0.0.1:9000

#

#location ~ \.php$ {

#   
root          
html;

#   
fastcgi_pass  
127.0.0.1:9000;

#   
fastcgi_index  index.php;

#   
fastcgi_param  SCRIPT_FILENAME 
/scripts$fastcgi_script_name;

#   
include       
fastcgi_params;

#}

# deny access to .htaccess files, if Apache's document
root

# concurs with nginx's one

#

#location ~ /\.ht {

#   
deny  all;

#}

}

# another
virtual host using mix of IP-, name-, and port-based
configuration

#

#server
{

#   
listen      
8000;

#   
listen      
somename:8080;

#   
server_name  somename 
alias  another.alias;

#    location /
{

#       
root   html;

#       
index  index.html index.htm;

#    }

#}

# HTTPS
server

#

#server
{

#   
listen      
443;

#   
server_name  localhost;

#   
ssl                 
on;

#   
ssl_certificate     
cert.pem;

#   
ssl_certificate_key  cert.key;

#   
ssl_session_timeout  5m;

#   
ssl_protocols  SSLv2 SSLv3 TLSv1;

#   
ssl_ciphers 
ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;

#   
ssl_prefer_server_ciphers  
on;

#    location /
{

#       
root   html;

#       
index  index.html index.htm;

#    }

#}

}

windows tomcat nginx session(当一台tomcat关闭后)的更多相关文章

  1. Tomcat集群,Nginx集群,Tomcat+Nginx 负载均衡配置,Tomcat+Nginx集群

    Tomcat集群,Nginx集群,Tomcat+Nginx 负载均衡配置,Tomcat+Nginx集群 >>>>>>>>>>>> ...

  2. Windows下nginx的启动,重启,关闭功能

    @echo off rem 提供Windows下nginx的启动,重启,关闭功能 echo ==================begin======================== cls :: ...

  3. redis+tomcat+nginx session共享

    http://www.cnblogs.com/zhrxidian/p/5432886.html系列课程 简洁明了 http://blog.csdn.net/grhlove123/article/det ...

  4. Windows server 2012 R2开机进入cmd,关闭后黑屏问题

    原因分析: 因为自己在卸载IIS的时候,不小心卸载了.net framework,系统没有了图形界面(由完整模式Full变为了核心模式core),需要重新恢复.net framework4.5. 解决 ...

  5. Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享

    Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享 ============================= 蕃薯耀 2017年11月27日 http: ...

  6. tomcat中session在两个webapp中实现共享

    现在遇到一个需求就是要求完成简单的单点登录,通过在一个tomcat实例中放置两个webapps应用ROOT应用和CEO应用来完成在ROOT应用登录后,在CEO可以直接使用,而未在ROOT应用登录时,不 ...

  7. 高级运维(五):构建memcached服务、LNMP+memcached、使用Tomcat设置Session、Tomcat实现session共享

    一.构建memcached服务 目标: 本案例要求先快速搭建好一台memcached服务器,并对memcached进行简单的添.删.改.查操作: 1> 安装memcached软件,并启动服务d ...

  8. tomcat redis session共享

    编译redis所需要的序列化包 安装 gradle Linux & MacOS users Configure your PATH environment variable to includ ...

  9. Tomcat学习总结(10)——Tomcat多实例冗余部署

    昨天在跟群友做技术交流的时候,了解到,有很多大公司都是采用了高可用的,分布式的,实例沉余1+台.但是在小公司的同学也很多,他们反映并不是所有公司都有那样的资源来供你调度.往往公司只会给你一台机器,因为 ...

随机推荐

  1. Java第三阶段学习(四、缓冲流)

    一.缓冲流: Java中提供了一套缓冲流,它的存在,可提高IO流的读写速度 缓冲流,根据流的分类分为:字节缓冲流与字符缓冲流. 二.字节缓冲流: 字节缓冲流根据流的方向,共有2个: 1.写入数据到流中 ...

  2. 【LOJ】#2541. 「PKUWC2018」猎人杀

    题解 一道神仙的题>< 我们毙掉一个人后总的w的和会减少,怎么看怎么像指数算法 然而,我们可以容斥-- 设\(\sum_{i = 1}^{n} w_{i} = Sum\) 我们把问题转化一 ...

  3. 【POJ】1740.A New Stone Game

    题解 想去学习一下博弈论的SG函数 不过貌似这道题就是猜结论并且证明 题意是,随便选择一堆石子,扔掉至少一个,然后从扔石子的这堆里选择任意多(可以不选)放到其他任意多的未选择完的石堆里 一堆石子,先手 ...

  4. 设置Loadrunner负载机临时文件目录

    设置Loadrunner负载机临时文件目录 最近在跑稳定性测试 3 X 24小时的时候,发现负载机产生的日志还运行记录等等竟然有100多G! C盘空间不足,但是D盘还有700多G空间呢,怎么让临时文件 ...

  5. nodejs 项目,请求返回Invalid Host header问题

    今天在linux上安装node,使用node做一个web服务器,在linux上安装各种依赖以后开始运行但是,出现了:Invalid Host header 的样式,在浏览器调试中发现是node返回的错 ...

  6. 单元测试+内存、SD卡、SP读写+XmlPullParser

    测试: 测试的相关概念 1.根据是否知道源代码分类: 黑盒测试: a - b - c 边值测试 测试逻辑业务 白盒测试: 根据源代码写测试方法 或者 测试用例; 2.根据测试的粒度分类: 方法测试:写 ...

  7. ubuntu16.04 删除内核

    一.背景 今天开机输入密码后,Ubuntu就卡在左下角有“Ubuntu 16.04 LTS”字样的那个界面,鼠标可以移动,但无法进入桌面.考虑到这个问题可能是因为ubuntu的自动更新造成的,于是重新 ...

  8. hdoj2191 珍惜现在,感恩生活(01背包 || 多重背包)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=2191 思路 由于每种大米可能不止一袋,所以是多重背包问题,可以直接使用解决多重背包问题的方法,也可以将 ...

  9. Ionic Js二十:选项卡栏操作

    ion-tabs ion-tabs 是有一组页面选项卡组成的选项卡栏.可以通过点击选项来切换页面. 对于 iOS,它会出现在屏幕的底部,Android会出现在屏幕的顶部(导航栏下面). 用法 < ...

  10. 30:最小的K个数

    import java.util.ArrayList; import java.util.TreeSet; /** * 面试题30:最小的K个数 * 输入n个整数,找出其中最小的K个数.例如输入4,5 ...