1. 在多个服务器上部署tomcat
(这里我用一台服务器的三个端口来模拟不同的tomcat,有多个服务器的话就不用配置这个了)
1. 解压获得三个tomcat目录
2. 修改3个tomcat的端口号
* vim tomcat/conf/server.xml (3个port都要和别的tomcat不一样)
<Server port="8001" shutdown="SHUTDOWN"> ---关闭端口
<Connector port="8888" protocol="HTTP/1.1" ---http协议端口
connectionTimeout="20000"
redirectPort="8443" />
<Connector port="10010" protocol="AJP/1.3" redirectPort="8443" /> ---AJP协议端口
3. 使用tomcat/bin/startup.sh逐个运行
2. Nginx
0.安装必要依赖
yum install -y gcc pcre-devel zlib-devel
1.下载Nginx
http://nginx.org/en/download.html
2.将Nginx上传到linux中,并解压缩
tar -zxvf nginx-1.20.1.tar.gz
4.在Nginx安装目录中执行如下命令:(指定安装位置)
./configure --prefix=/usr/nginx
5.执行上述命令后,执行如下命令:
make && make install
6.编译完成后进入编译安装目录/usr/nginx目录中查看:
[root@localhost nginx]# ls -l
总用量 4
drwxr-xr-x. 2 root root 4096 10月 14 21:17 conf
drwxr-xr-x. 2 root root 40 10月 14 21:17 html
drwxr-xr-x. 2 root root 6 10月 14 21:17 logs
drwxr-xr-x. 2 root root 19 10月 14 21:17 sbin
7.启动nginx,进入nginx安装目录的sbin目录中执行:
./nginx
8.在windows中浏览器访问,可以看到nginx欢迎页面:
http://192.168.72.132:80/
注意:关闭网络防火墙
9.关闭nginx,进入nginx安装目录的sbin目录中执行:
./nginx -s stop
10. 将多个tomcat配置到nginx的配置文件中:(nginx/config/nginx.conf)
1).在server标签的上面加入如下配置:
upstream tomcat-servers {
server 192.168.72.131:8081;
server 192.168.72.131:8082;
server 192.168.72.131:8083;
}
2).将配置文件中 location /替换为如下配置:
location / {
proxy_pass http://tomcat-servers;
proxy_redirect off;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $http_host;
proxy_next_upstream http_502 http_504 error timeout invalid_header;
}
11 启动
nginx的一些参数
# 1.轮询
说明: 默认策略,每个请求会按时间顺序逐一分配到不同的后端服务器
# 2.weight 权重
说明: weight参数用于指定轮询几率,weight的默认值为1,;weight的数值与访问比率成正比
upstream tomcat-servers {
server localhost:8080 weight=2;
server localhost:8081;
server localhost:8082 backup;
}
注意:1.权重越高分配到需要处理的请求越多。2.此策略可以与least_conn和ip_hash结合使用主要用于后端服务器性能不均
# 3.ip_hash 4%3=1
说明:指定负载均衡器按照基于客户端IP的分配方式,这个方法确保了相同的客户端的请求一直发送到相同的服务器,以保证session会话。这样每个访客都固定访问一个后端服务器,可以解决session不能跨服务器的问题。
upstream tomcat-servers {
ip_hash; #保证每个访客固定访问一个后端服务器
server localhost:8080;
......
}
# 4.least_conn
说明: 把请求转发给连接数较少的后端服务器。轮询算法是把请求平均的转发给各个后端,使它们的负载大致相同;但是,有些请求占用的时间很长,会导致其所在的后端负载较高。这种情况下,least_conn这种方式就可以达到更好的负载均衡效果。
upstream tomcat-servers{
least_conn; #把请求转发给连接数较少的后端服务器
server localhost:8080;
}