目标:Nginx做为HttpServer,连接多个tomcat应用实例,进行负载均衡。
注:本例程以一台机器为例子,即同一台机器上装一个nginx和2个Tomcat且安装了JDK1.7。
1、安装Nginx
安装Nginx教程
2、配置两个Tomcat
在本机上配置两个Tomcat,分别为tomcat7-8081、tomcat7-8082。
tomcat7-8081访问地址:http://localhost:8081,浏览显示内容:this is 8081 port
tomcat7-8082访问地址:http://localhost:8082,浏览显示内容:this is 8082 port
D:\div\tomcat7-8081\webapps\ROOT\index.jsp文件内容为:
this is 8081 port
D:\div\tomcat7-8082\webapps\ROOT\index.jsp文件内容为:
this is 8082 port
在同一台服务器上配置多个Tomcat教程
如果要在一台服务器上配置多个Tomcat,主要就是要避免Tomcat服务器的端口冲突的问题。只需要修改CATALINA_HOME\conf\server.xml中的启动端口和连接端口就OK了!
下面我们把配置的详细过程写在下面,以供参考:(此例以配置三个Tomcat为例) 1. 下载apache-tomcat-7.0.63,下载下来的文件为apache-tomcat-7.0.63.zip. 2. 解压该压缩包到D:/div/目录下。 3. 修改解压文件夹名字为:tomcat7-8080 4. 在D:/div/目录下创建该文件夹的两个副本,分别更名为:tomcat7-8081、tomcat7-8082 5. 添加环境变量:右键单击我的电脑->选择属性->选择高级->选择环境变量:添加系统变量: CATALINA_HOME_8080,其值为:D:\div\tomcat7-8080; CATALINA_HOME_8081,其值为:D:\div\tomcat7-8081; CATALINA_HOME_8082,其值为:D:\div\tomcat7-8082; 6. 修改启动端口和关闭端口: 进入D:\div\tomcat7-8081\conf\目录,打开server.xml文件,修改下面两个地方: (1)修改这个port=”8006”,原来默认的为:8005,使得它的关闭端口和另一个关闭端口不发生冲突。 (2) 修改port=”8081”,原来默认的为“8080”,使得它的连接端口和另一个不冲突。 (3) 修改这个port=”8010”,原来默认的为:8009,AJP 1.3 Connector定义的地方。 7. 修改startup.bat和catalina.bat文件内容: (1) 打开D:\div\tomcat7-8081\bin\startup.bat文件,把其中所有CATALINA_HOME替换为CATALINA_HOME_8081。 (2) 打开D:\div\tomcat7-8081\bin\catalina.bat文件,把其中所有CATALINA_HOME替换为CATALINA_HOME_8081。 tomcat7-8082配置方法跟配置tomcat7-8081步骤一样的。 8.启动Tomcat,在命令行下分别进入三个不同的Tomcat安装目录下,执行startup.bat,分别启动三个Tomcat。然后在浏览器中输入: http://localhost:8080 http://localhost:8081 http://localhost:8082 9. 至此,我们已经在一台服务器上配置了三个Tomcat。
这样我们就成功的搭建了一个nginx服务,成功的配置了两个tomcat应用实例。
3、Nginx+Tomcat负载均衡配置
这里只需要修改Nginx的配置,让它通过tomcat来转发。
a、nginx.conf配置文件
worker_processes 1; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 10; include extra/upstream01.conf; }
b、extra/upstream01.conf文件,负载均衡配置信息
upstream mysite { server localhost:8081 weight=5; server localhost:8082 weight=5; } server { listen 80; server_name localhost; location / { proxy_pass http://mysite; } }
当有请求到localhost时,请求会被分发到对应的upstream设置的服务器列表上,每一次请求分发的服务器都是随机的。
接着在运行一次start nginx,当你不断刷新http://localhost的时候,浏览器上就会来回切换"this is 8081 port"和"this is 8082 port"。
这样说明负载均衡配置成功了!!!!!!