在负载均衡方面,Nginx和Tomcat的实现方式略有不同。Nginx作为反向代理服务器,可以直接处理并分发请求到后端服务器,包括Tomcat。它可以使用不同的负载均衡算法来分发请求,将负载均衡的任务集中在Nginx上。而Tomcat通常通过与Apache HTTP服务器或Nginx等负载均衡器结合使用,实现请求的负载均衡。
通过将Nginx与Tomcat结合使用,可以充分利用Nginx的高性能和负载均衡功能,同时利用Tomcat来处理Java Web应用程序。这样可以实现灵活、高性能的负载均衡架构。
方案一
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文件内容为:
<!DOCTYPE html>
<html lang="en">
<head>this is 8081 port</head>
</html>
D:\div\tomcat7-8082\webapps\ROOT\index.jsp文件内容为:
<!DOCTYPE html>
<html lang="en">
<head>this is 8082 port</head>
</html>
在同一台服务器上配置多个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)<Server port="8006" shutdown="SHUTDOWN">
修改这个port=”8006”,原来默认的为:8005,使得它的关闭端口和另一个关闭端口不发生冲突。
(2)<Connector port="8081" maxHttpHeaderSize="8192"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" redirectPort="8443" acceptCount="100"
connectionTimeout="20000" disableUploadTimeout="true" />
修改port=”8081”,原来默认的为“8080”,使得它的连接端口和另一个不冲突。
(3)<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
修改这个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”。
这样说明负载均衡配置成功了
方案二
通俗点讲,负载均衡就是因为访问流量太大,导致项目访问不流畅、甚至宕掉,所以通过一种分流的方式来缓解这种情况。
1、首先下载Nginx,要下载稳定版:
2、然后解压两个Tomcat,分别命名为apache-tomcat-6.0.33-1和apache-tomcat-6.0.33-2:
3、然后修改这两个Tomcat的启动端口,分别为18080和28080,下面以修改第一台Tomcat为例,打开Tomcat的conf目录下的server.xml:
共需修改3处端口:
当然第二台Tomcat也一样,如下图:
4、然后启动两个Tomcat,并访问,看是否正常:
5、然后修改上面两个Tomcat的默认页面(为了区分下面到底访问的是那一台Tomcat,随便改一下即可):
改完以后,进行访问,如下图:
6、OK,现在我们可以开始配置Nginx来实现负载均衡了,其实非常的简单,只需要配置好Nginx的配置文件即可:
配置如下(这里只进行了简单的配置,实际生产环境可以进行更详细完善配置):
核心配置如下:
7、首先,我们启动Nginx:
8、然后我们即可输入:localhost/index.jsp查看运行状况了第一次访问,发现访问的是Tomcat2上的程序:然后刷新,访问的还是Tomcat2上的程序:再刷新,发现变为了Tomcat1上的程序:再刷新,发现又变为了Tomcat2上的程序:9.到此,我们利用Nginx已经实现了负载均衡的Tomcat集群。我们不断的刷新,发现访问Tomcat2的概率大概是Tomcat1的2倍,这是因为我们在Nginx中配置的两台Tomcat的权重起的作用,如下图: