使用nginx 对Tomcat进行负载集群,和redis进行session共享

阅读更多
一、准备工作

1、下载nginx中间件。地址 http://nginx.org/en/download.html
2、下载tomcat建议使用tomcat7。 https://tomcat.apache.org/download-70.cgi
3、下载Redis缓存工具 https://redis.io/download
4、下载redismanger缓存管理工具 https://redisdesktop.com


二、Nginx负载均衡配置
集群配置的几种策略
参考 https://blog.csdn.net/u012383839/article/details/79801105
引用

# 使用默认策略,轮询
upstream localhost{
    # 下面介绍几种负载均衡策略,其中轮询、weight、ip_hash是nginx内置的,可以直接使用。fair和url_hash需要第三方支持才可以使用。
    # 1、轮询(默认):每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
    server localhost:8288;
    server localhost:8289;
    server localhost:8290;

    # 2、weight:指定权重,按照权重进行请求的分配。wight和访问比例成正比,适合后端服务器性能不均的情况。
    # 下面的配置就会经常访问8288的服务。如果后端服务器8288 down掉,能够立刻切换到8299或者8290。如果8288再次启动,则又能回到原有的权重配置上。8288可以继续提供服务。
    # server localhost:8288 weight=10;
    # server localhost:8289 weight=1;
    # server localhost:8290 weight=1;

    # 3、ip_hash:每个请求按照ip的hash结果进行分配,这样的话每个访客固定请求一个后端服务器,可以解决session没共享的问题。
    # 如果8288 down掉,则依然可以访问,可能会缓存8289或者8290。如果8288启动,则会从8289或8290切换到8288。
    # ip_hash;
    # server localhost:8288;
    # server localhost:8289;
    # server localhost:8290;

    # 4、fair(第三方):后端服务器响应时间短的优先分配。
    # fair;
    # server localhost:8288;
    # server localhost:8289;
    # server localhost:8290;

    # 5、url_hash(第三方):按访问的url的hash结果来分配请求,这样相同url会分配到相同的后端服务器。适合后端服务器有缓存的情况。
    # hash $request_uri;
    # hash_method crc32;
    # server localhost:8288;
    # server localhost:8289;
    # server localhost:8290;
}


----server节点下配置如下:
listen       8080;
server_name  localhost; # 这里是服务器的IP或者域名
location / {
    proxy_connect_timeout 30;
    proxy_send_timeout 60;
    proxy_read_timeout 60;
    proxy_pass http://localhost;

proxy_set_header Host $host:$server_port;
#proxy_set_header X-Real-IP $remote_addr;
#proxy_set_header X-Forwarded-For $remote_addr;
}



三、多个tomcat中session共享的问题。

在nginx中ip_hash的策略可以解决session共享的问题。
一般有几种方案。
1、使用tomcat之前的session复制,但是这种对于tomcat过多会不适用。参考 https://blog.csdn.net/u012383839/article/details/79756368
2、使用缓存redis实现session共享。需要注意tomcat版本和tomcat-redis-session-manager-1.1.jar的兼容。tomcat下context.xml文件的配置,配置tomcat和redis的关联注意ip和端口
引用


host="localhost"
port="6379"
database="0" maxInactiveInterval="60" />

参考 https://blog.csdn.net/hua1586981/article/details/78132710

你可能感兴趣的:(nginx,tomcat,集群)