Nginx tomcat8.5集群 与 redis session 共享

(一) nginx配置tomcat集群

1.配置nginx.cnf文件如下:

server {
      listen 80 default_server; server_name _; 
      return 444; #过滤其他域名的请求,返回444状态码 
}
server {
       listen 80; 
       server_name wx.ppp.com; # www.aaa.com域名  
       location / 
         { 
        proxy_pass http://wx.ppp.com; 
    #   proxy_pass http://localhost:8088; # 对应端口号8088 
            #proxy_ignore_headers X-Accel-Expires Expires Cache-Control; 
            #proxy_ignore_headers Set-Cookie; 
            #proxy_hide_header Set-Cookie; 
            #proxy_hide_header X-powered-by; 
            proxy_set_header X-Real-IP $remote_addr; 
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
            proxy_set_header X-Forwarded-Proto https; 
            proxy_set_header Host $http_host; 
            expires 10m;
         } 
}

#服务器的集群  
upstream  wx.ppp.com {  #服务器集群名字   
        server    127.0.0.1:8088  weight=1;#服务器配置   weight是权重的意思,权重越大,分配的概率越大。  
        server    127.0.0.1:38088  weight=1;  
    }

(二)配置tomcat 与 redis session共享

1、安装redis

下载:wget -q http://download.redis.io/releases/redis-3.2.1.tar.gz

解压:tar -xzf redis-3.2.1.tar.gz

切换目录 cd ./redis-3.2.1

编译:make

安装:make install

运行:src/redis-server

2、 添加以下jar包:

tomcat85-session-redis-1.0.jar

jedis-2.9.0.jar

commons-pool2-2.4.2.jar

3、分别修改集群中tomcat的 context.xml 文件 ,在 Context下添加如下代码:



4、重启tomcat ,若启动正常则配置成功。

5、浏览器中分别访问集群tomcat 中的页面,观察sessionid 是否一致。

6、创建读写session jsp,一个用来写session,一个用来读session。

read.jsp读取session中的 userId

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>




Read session


Server : Server 1 (因需将页面部署在不同Tomcat,以测试能读取另一台Tomcat设置的Session,请自行设服务器标识)
<%=request.getSession().getAttribute("userId")%>

write.jsp写入userId到session中

<%@ page import="java.util.Date"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>




Write session


Server : Server 1 (因需将页面部署在不同Tomcat,以测试能读取另一台Tomcat设置的Session,请自行设服务器标识)
Write session <% request.getSession().setAttribute("userId", new Date().getTime()); %>

分别将两个jsp文件放到tomcat中,在其中的一个tomcat中运行 write.jsp写入userId。然后其他tomcat中运行 read.jsp查看userId的值,发现会读取到第一个页面写入的userId,并且和其他tomcat中读取的值一致。大功告成!

注:tomcat85-session-redis-1.0.jar下载地址:http://download.csdn.net/download/wjwj1203/9934717

你可能感兴趣的:(Nginx tomcat8.5集群 与 redis session 共享)