一、为什么需要对Tomcat服务器做负载均衡: 

Tomcat服务器作为一个Web服务器,其并发数在300-500之间,如果有超过500的并发数便会出现Tomcat不能响应新的请求的情况,严重影响网站的运行。另外,在访问量大的情况下,Tomcat的线程数会不断增加。由于Tomcat自身对内存的占用有控制,当对内存的占用达到最大值时便会出现内存溢出,对网站的访问严重超时等现象,这时便需要重新启动Tomcat以释放占用的内存,这样做便会阻断网站运行。

所以对Tomcat做负载均衡便很有必要。目前可以和Tomcat做负载均衡的主流服务器是Apache,但是Nginx由于功能多、配置简单等优点逐渐成为很多负载均衡服务器的首选。Nginx的并发数可达到50000,所以理论上可以和Tomcat以1:100的比例来配置,这样便可以很好的解决网站并发瓶颈问题。而且Nginx、apache是基于http反向代理方式,位于ISO模型的第七层应用层。直白些就是TCP UDP 和http协议的区别,Nginx不能为基于TCP协议的应用提供负载均衡。

 二. 配置方法

1.下载相应的服务器,本人两个Tomcat的版本都采用6.0的.Nginx采用1.5.6版本

2. Nginx介绍

目录结构

Nginx-

|_  conf   配置目录

|_  contrib

|_  docs 文档目录

|_  logs  日志目录

|_  temp 临时文件目录

|_  html 静态页面目录

|_  nginx.exe 主程序

window下安装Nginx极其简单,解压缩到一个无空格的英文目录即可(个人习惯,担心中文出问题),双击nginx启动,这里我安装到:D:\test目录. 若果想停止nginx,dos环境运行命令:nginx -s stop.

nginx.conf配置

Nginx配置文件默认在conf目录,主要配置文件为nginx.conf,我们安装在D:\server\nginx-0.8.20、默认主配置文件为D:\server\nginx-0.8.20\nginx.conf。下面是nginx作为前端反向代理服务器的配置。

  1. Nginx.conf代码
  2. #Nginx所用用户和组,window下不指定
  3. #user  nobody;
  4. #工作的子进程(通常等于CPU数量或者1倍于CPU)
  5. worker_processes  1;
  6. #错误日志存放路径
  7. #error_log  logs/error.log;
  8. #error_log  logs/error.log  notice;
  9. #error_log  logs/error.log  info;
  10. #指定pid存放文件
  11. #pid        logs/nginx.pid;
  12. events {
  13. #允许最大连接数
  14. worker_connections  1024;
  15. }
  16. http {
  17. include       mime.types;
  18. default_type  application/octet-stream;
  19. #定义日志格式
  20. #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
  21. #                  '$status $body_bytes_sent "$http_referer" '
  22. #                  '"$http_user_agent" "$http_x_forwarded_for"';
  23. #access_log  logs/access.log  main;
  24. sendfile        on;
  25. #tcp_nopush     on;
  26. #keepalive_timeout  0;
  27. keepalive_timeout  65;
  28. #客户端上传文件大小控制
  29. client_max_body_size 8m;
  30. #gzip  on;
  31. upstream localhost {
  32. server localhost:8080;
  33. server localhost:8000;
  34. #根据ip计算将请求分配各那个后端tomcat,许多人误认为可以解决session问题,其实并不能。
  35. #同一机器在多网情况下,路由切换,ip可能不同
  36. ip_hash;
  37. }
  38. server {
  39. listen       9999;
  40. server_name  localhost;
  41. #charset koi8-r;
  42. #access_log  logs/host.access.log  main;
  43. location / {
  44. root html;
  45. index index.html index.htm;
  46. #此处的 http://localhost与upstream localhost对应
  47. proxy_pass  http://localhost;
  48. proxy_redirect off;
  49. proxy_set_header Host $host;
  50. proxy_set_header X-Real-IP $remote_addr;
  51. proxy_set_header  X-Forwarded-For $proxy_add_x_forwarded_for;
  52. client_max_body_size   10m;
  53. client_body_buffer_size  128k;
  54. proxy_connect_timeout  100;
  55. proxy_send_timeout   100;
  56. proxy_read_timeout 100;
  57. proxy_buffer_size 4k;
  58. proxy_buffers  4 32k;
  59. proxy_busy_buffers_size 64k;
  60. proxy_temp_file_write_size  64k;
  61. }
  62. #error_page  404              /404.html;
  63. # redirect server error pages to the static page /50x.html
  64. #
  65. error_page   500 502 503 504  /50x.html;
  66. location = /50x.html {
  67. root   html;
  68. }
  69. # proxy the PHP scripts to Apache listening on 127.0.0.1:80
  70. #
  71. #location ~ \.php$ {
  72. #    proxy_pass   http://127.0.0.1;
  73. #}
  74. # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
  75. #
  76. #location ~ \.php$ {
  77. #    root           html;
  78. #    fastcgi_pass   127.0.0.1:9000;
  79. #    fastcgi_index  index.php;
  80. #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
  81. #    include        fastcgi_params;
  82. #}
  83. # deny access to .htaccess files, if Apache's document root
  84. # concurs with nginx's one
  85. #
  86. #location ~ /\.ht {
  87. #    deny  all;
  88. #}
  89. }
  90. # another virtual host using mix of IP-, name-, and port-based configuration
  91. #
  92. #server {
  93. #    listen       8000;
  94. #    listen       somename:8080;
  95. #    server_name  somename  alias  another.alias;
  96. #    location / {
  97. #        root   html;
  98. #        index  index.html index.htm;
  99. #    }
  100. #}
  101. # HTTPS server
  102. #
  103. #server {
  104. #    listen       443 ssl;
  105. #    server_name  localhost;
  106. #    ssl_certificate      cert.pem;
  107. #    ssl_certificate_key  cert.key;
  108. #    ssl_session_cache    shared:SSL:1m;
  109. #    ssl_session_timeout  5m;
  110. #    ssl_ciphers  HIGH:!aNULL:!MD5;
  111. #    ssl_prefer_server_ciphers  on;
  112. #    location / {
  113. #        root   html;
  114. #        index  index.html index.htm;
  115. #    }
  116. #}

修改Nginx配置文件nginx.conf

①       在#gzip  on;后面加入下面配置:

  1. upstream localhost {
  2. server localhost:8080;
  3. server localhost:8088;
  4. ip_hash;
  1. }

其中serverlocalhost:8080为第一个Tomcat的启动地址,server localhost:8088为第二个Tomcat的启动地址,ip_hash用于做session同步其实是不起作用的。

② 修改第一个server{}配置中的listen  80;改为新的端口号,因为我的本机80端口被其他服务器占用,因此将此处改为listen 9999;

  1. location / {
  1. root   html;
  2. index  index.html index.htm;
  3. }
  4. 改为:
  5. location / {
  6. root html;
  7. index index.html index.htm;
  8. #此处的 http://localhost与upstream localhost对应
  9. proxy_pass  http://localhost;
  10. proxy_redirect off;
  11. proxy_set_header Host $host;
  12. proxy_set_header X-Real-IP $remote_addr;
  13. proxy_set_header  X-Forwarded-For $proxy_add_x_forwarded_for;
  14. client_max_body_size   10m;
  15. client_body_buffer_size  128k;
  16. proxy_connect_timeout  100;
  17. proxy_send_timeout   100;
  18. proxy_read_timeout 100;
  19. proxy_buffer_size 4k;
  20. proxy_buffers  4 32k;
  21. proxy_busy_buffers_size 64k;
  22. proxy_temp_file_write_size  64k;
  23. }

3.tomcat的配置

修改其中一个tomcat的server.xml配置文件即可

第一处端口修改:

  1. <!--  修改port端口:18006 俩个tomcat不能重复,端口随意,别太小-->
  2. lt;Server port="8000" shutdown="SHUTDOWN">

第二处端口修改

  1. <!-- port="18081" tomcat监听端口,随意设置,别太小 -->
  2. <Connector port="18081" protocol="HTTP/1.1"
  3. connectionTimeout="20000"
  4. redirectPort="8443" />

第三处端口修改:

Java代码

  1. "8009" protocol="AJP/1.3" redirectPort="8443" />

验证配置与测试负载均衡

  首先测试nginx配置是否正确,测试命令:nginx -t  (默认验证:conf\nginx.conf),也可以指定配置文件路径

其次验证两个tomcat,启动两个tomcat不出现端口冲突即为成功

最后验证配置负载均衡,启动nginx双机nginx.exe文件或者用start nginx启动 打开浏览器输入地址http://localhost:9999看到下面画面表示成功:

此图说明已经成功跳转到tomcat 输入测试路径可以看到测试项目的首页就表示基本成功。

至此window下nginx+tomcat负载均衡配置结束,关于tomcat Session的问题通常是采用memcached,或者采用nginx_upstream_jvm_route,他是一个Nginx的扩展模块,用来实现基于 Cookie的 Session Sticky的功能。如果tomcat过多不建议session同步,server间相互同步session很耗资源,高并发环境容易引起Session风暴。请根据自己应用情况合理采纳session解决方案。

=========================================================================================

在nginx目录下,运行 nginx -t ,出现如下图所示则配置正确。

然后启动nginx

一些命令:

start nginx 启动nginx

nginx -s stop 停止nginx

配置Tomcat,端口号分别为9001,9002 ,调试至正常运行。启动tomcat

两个Tomcat部署完毕后,输入http://localhost:9000/,刷新多次后,注意上图中标注的地方,THIS IS TOMCAT-1,THIS IS TOMCAT-2  说明访问了不同的tomcat .

至此,windows下nginx tomcat 负载均衡配置结束。

=========================================================================================

一、为什么需要对Tomcat服务器做负载均衡?
    Tomcat服务器作为一个Web服务器,其并发数在300-500之间,如果超过500的并发数会出现Tomcat不能响应新的请求的情况,严重影响网站的运行。同时如果访问量非常大的情况下,Tomcat的线程数会不断增加。因此会占据大量内存,严重时出现内存溢出的现象,这时需要重启Tomcat以释放内存,阻断了网站的运行。
    所以对Tomcat做负载均衡便很有必要。目前可以和Tomcat做负载均衡的主流服务器是Apache,但是Nginx由于功能多、配置简单等优点成为很多负载均衡服务器的首选。Nginx的并发数可达到50000,所以理论上可以和Tomcat以1:100的比例来配置,这边可以很好的解决网站并发瓶颈问题。

二、Nginx+Tomca在Windows下负载均衡的配置:
    先秀一下我的环境: Nginx1.3.11 + Tomcat 6.0(2个)、Win 7。
    下面是配置过程:
    1、将nginx-1.3.11.rar直接解压到D:盘。
    2、将apache-tomcat-6.0.26.rar解压到D:盘,既然是做负载均衡将tomcat拷贝两份,分别命名tomcat_1、tomcat_2。
    3、将要发布的项目部署分别部署到两个Tomcat根目录下的webapps下,保证两个Tomcat下的项目名相同。
    4、修改tomcat_2的配置文件,该配置文件位于/conf下,文件名为server.xml, 修改其中的<Server port="8005" shutdown="SHUTDOWN">            为<Server port="8006" shutdown="SHUTDOWN">,修改其中的

1
2
3
<Connector port="8080 protocol="HTTP/1.1"
          connectionTimeout="20000"
          redirectPort="8443"/>

1
2
3
<Connector port="8088 protocol="HTTP/1.1"
        connectionTimeout="20000"
        redirectPort="8443"/>
1
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

(ajp是一个协议,tomcat可以用来服务器集群,也可以在csdn找到更详细的ajp资料)为

1
<Connector port="7009" protocol="AJP/1.3" redirectPort="8443" />

5、修改Nginx配置文件nginx.conf,该文件位于Nginx根目录下的/conf目录下
    a、在#gzip on;后面加入下面配置:

1
2
3
4
5
upstream localhost {
    server localhost:8080 weight=5;
    server localhost:8080 weight=5;
    ip_hash;
}

其中server localhost:8080为tomcat_1的启动地址, server localhsot:8088为tomcat_2的启动地址,ip_hash用于做session同步。 
    b、修改

1
2
3
4
location / {
    root html;
    index index.html index.htm;
}

改为:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
location / {
      root   html;
      index  index.html index.htm;
      proxy_pass   http://localhost;
      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_timeout   90;
      proxy_send_timeout   90;
      proxy_read_timeout   90;
      proxy_buffer_size   4k;
      proxy_buffers   4 32k;
      proxy_busy_buffers_size   64k;
      proxy_temp_file_write_size  64k;        
  }

其中proxy_pass参数和upstream localhost{}对应。

经过上面这些步骤,负载均衡配置完成,下面分别启动tomcat_1、tomcat_2,然后双击nginx根目录下nginx.exe文件或者使用start nginx启动(关闭是: nginx -s stop),打开浏览器,输入地址: http://localhost便可看到tomcat的首页了。

nginx(Window下安装 & 配置文件参数说明 & 实例)的更多相关文章

  1. 转://Window下安装Oracle ASM单实例数据库

    之前做的Oracle ASM实验都是基于Linux或者Unix操作系统的,最近想试试如何在Windows环境下使用Oracle ASM.本文介绍如何在windows下创建裸设备,并创建ASM磁盘组以及 ...

  2. Window 下安装

    Window 下安装 下载地址:https://github.com/MSOpenTech/redis/releases Redis 支持 32 位和 64 位.这个需要根据你系统平台的实际情况选择, ...

  3. Window 下安装 Redis

    Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. 一.Window 下安装 redis https://github.com/MicrosoftArchive/r ...

  4. window下安装php7的memcache扩展

    安装memcache:http://www.runoob.com/memcached/memcached-connection.html1.4.4 c:\memcached\memcached.exe ...

  5. window下安装 node ,并搭建 vue 项目

    uname -a  命令查看到我的Linux系统位数是64位(备注:x86_64表示64位系统, i686 i386表示32位系统) window下安装node 1.在官网上选择对应的位数的msi安装 ...

  6. window下安装cross-env解决NODE_ENV ts-node 不是内部或外部命令,也不是可运行的程序 或批处理文件 问题

    window下安装cross-env解决NODE_ENV ts-node 不是内部或外部命令,也不是可运行的程序 或批处理文件 问题 在git bash上启动无法进行调试,采用cross-env后可以 ...

  7. window下安装redis报错: creating server tcp listening socket 127.0.0.1:6379: bind No error

    window下安装redis报错: creating server tcp listening socket 127.0.0.1:6379: bind No error 解决: 如果没有配置环境,在安 ...

  8. window下安装rsyncServer

    window下安装rsyncServer---------------------------------1. 解压cwRsyncServer_4.0.5_Installer.zip,安装. 2. 复 ...

  9. window下安装composer步骤(linux待研究)

    window下安装composer步骤--注意(安装完之后需要重启电脑才能生效) 转发:https://blog.csdn.net/wengedexiaozao/article/details/798 ...

随机推荐

  1. ife2015-task2-4-5

    task2-4.html<!DOCTYPE html><html><head lang="en"> <meta charset=" ...

  2. VBO与VAO 【转】

    我想大家都已经熟悉VBO了吧.在GL3.0时代的VBO大体还是处于最重要的地位,但是与此同时也出现了不少新的用法和辅助役,其中一个就是VAO.本文大致小记一下这两者的联系,帮助大家理解一下这个角色.— ...

  3. cubemap

    cubemap 画的时候 是一张一张画 并不是画成 ------- |       | |       |        |       |       | |        | 这样一个位置 而是一 ...

  4. pclint在VS2013中的配置

    1.安装pclint a. 从http://download.csdn.net/detail/finewind/8426979下载破解版的pclint9i版: b. 点击pclint9setuo.ex ...

  5. 第一章 初识shiro

    shiro学习教程来自开涛大神的博客:http://jinnianshilongnian.iteye.com/blog/2018936 第一章 初识shiro 简单了解shiro主要记住三张图即可. ...

  6. 数据库字段名称转java字段名称

    /** * * @Title: changeToJavaFiled * @Description: TODO(将数据库中带下划线的字段转换为Java常用的驼峰字段) * @param @param f ...

  7. Resin服务器部署web项目

    Resin服务器部署web项目 学习了:https://blog.csdn.net/eff666/article/details/53324167 需要配置resin.xml文件: <host ...

  8. 10. 修改端口号【从零开始学Spring Boot】

    转载:http://blog.csdn.net/linxingliang/article/details/51637017 spring boot 默认端口是8080,如果想要进行更改的话,只需要修改 ...

  9. 使用JMeter录制手机App脚本

    Apache JMeter是100%的Java桌面应用程序,用于对软件做压力测试.它最初被设计用于Web应用测试,但后来扩展到其他测试领域.现如今这款软件越来越受到测试人员的青睐,相比于LoadRun ...

  10. SpringMVC处理MySQL BLOB字段的下载

    任务: uos.docfile的content字段是longblob类型,通过Web点击链接能下载到存储在这个字段里的文件.Web点击链接类似如下形式: http://localhost:8080/d ...