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;
    }