Nginx+Tomca+Redist搭建高性能负载均衡集群及session共享
一、工具
nginx-1.8.0
apache-tomcat-6.0.33
Redis-x64-3.2.100
二、Nginx配置tomcat步骤
1、首先下载Nginx,要下载稳定版:
2、然后解压两个Tomcat(根据需要解压N个),分别命名为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的配置文件即可:
配置如下(这里只进行了简单的配置,实际生产环境可以进行更详细完善配置):
1. worker_processes 1;#工作进程的个数,一般与计算机的cpu核数一致
2.
3. events {
4. worker_connections 1024;#单个进程最大连接数(最大连接数=连接数*进程数)
5. }
6.
7. http {
8. include mime.types; #文件扩展名与文件类型映射表
9. default_type application/octet-stream;#默认文件类型
10. sendfile on;#开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的负载。注意:如果图片显示不正常把这个改成off。
11.
12. keepalive_timeout 65; #长连接超时时间,单位是秒
13.
14. gzip on;#启用Gizp压缩
15.
16. #服务器的集群
17. upstream netitcast.com { #服务器集群名字
18. server 127.0.0.1:18080 weight=1;#服务器配置 weight是权重的意思,权重越大,分配的概率越大。
19. server 127.0.0.1:28080 weight=2;
20. }
21.
22. #当前的Nginx的配置
23. server {
24. listen 80;#监听80端口,可以改成其他端口
25. server_name localhost;############## 当前服务的域名
26.
27. location / {
28. proxy_pass http://netitcast.com;
29. proxy_redirect default;
30. }
31.
32. error_page 500 502 503 504 /50x.html;
33. location = /50x.html {
34. root html;
35. }
36. }
37. }
核心配置如下:
到此配置完成,下面开始演示负载均衡。
7、首先,我们启动Nginx:
8、然后我们即可输入:localhost/index.jsp查看运行状况了
第一次访问,发现访问的是Tomcat2上的程序:
到此,我们利用Nginx已经实现了负载均衡的Tomcat集群。我们不断的刷新,发现访问Tomcat2的概率大概是Tomcat1的2倍,这是因为我们在Nginx中配置的两台Tomcat的权重起的作用,如下图:
如有时nginx不好使,可到任务管理器中查看是否已有nginx.exe,如有将进行结束后重新启动nginx。
三、session共享采用redis
1、下载redis
(下载地址:https://github.com/MicrosoftArchive/redis/releases)
根据自己电脑系统选择对应版本
2、将下载的redis解压到指定文件夹
3、启动redis服务(进入到cmd中,切换到redis所在文件夹)
启动命令为redis-server.exe redis.windows.conf
4、修改nginx的配置文件nginx.cof,在server后添加max_fails=1 fail_timout=10s,两个tomcat都添加上。
upstream netitcast.com { #服务器集群名字
#server 127.0.0.1:8080 weight=1 srun_id=tomcat8;#服务器配置weight是权重的意思,权重越大,分配的概率越大。
server 127.0.0.1:28080 weight=2 max_fails=1fail_timeout=10s;
server 127.0.0.1:18080 weight=1 max_fails=1fail_timeout=10s;
}
5、修改tomcat的context.xml配置文件
在tomcat的context.xml配置文件中添加以下代码,(如redis有密码需要添加password=”***”)
<ValveclassName="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve"/>
<ManagerclassName="com.orangefunction.tomcat.redissessions.RedisSessionManager"
host="127.0.0.1"
port="6379"
database="0"
maxInactiveInterval="60" />
6、下载以下jar包,并分别添加到需要集群的tomcat的lib下
tomcat-redis-session-manager1.2.jar
jedis-2.6.2.jar
tomcat-juli.jar
tomcat-juli-adapters.jar
commons-pool2-2.0.jar
添加完jar包启动tomcat的时候如报ClassNotFoundException:com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve。则是因为所下载的tomcat-redis-session-manager1.2.jar
中没有com.orangefunction.tomcat.redissessions.RedisSession,需要到官网下载源码自己重新打成jar包放到tomcat的lib中将之前的tomcat-redis-session-manager1.2.jar替换掉。