Nginx+tomcat集群使用redis共享session

一 :nginx负载均衡

当Tomcat当做独立的Servlet容器来运行时,可看做是能运行Java Servlet的独立Web服务器。

此外 Tomcat还可以作为其他Web服务器进程内或者进程外的Servlet容器,从而与其他Web服务器集成(Apache Nginx IIS 等)

集成的意义在于:对于不支持运行java Servlet的其他Web服务器,可以通过集成Tomcat来提供运行Servlet的功能。

——————————Tomcat与JavaWeb开发技术详解(孙卫琴的一本书)

Nginx 通过Tomcat来运行Servlet容器。也可以 对集群的tomcat的负载进行均衡。(在后台多个Tomcat进行集群时,nginx把来自客户端的请求 随机分发到某一台Tomcat上)

下面看一个简单的demo

nginx.conf负载均衡的关键配置

http {
  include mime.types;
  default_type application/octet-stream;

  sendfile on;

  keepalive_timeout 65;

  upstream tomcatserver{
    server 119.23.50.194:9080 weight=1;
    server 119.23.50.194:8080 weight=2;
  }
  server {
    listen 80;
    server_name localhost;
    location / {
      proxy_pass http://tomcatserver;
    }
  }
}

配置表示,nignx的断开时80端口,也就是当我们直接输入ip的时候

会直接进入nginx的根路径。location / 通过proxy_pass指向server 119.23.50.194:9080(三分之一的概率);或者 server 119.23.50.194:8080(三分之二的概率);

概率可通过权重 weight配置。

思考:前端的请求会随机分发到不同的Servlet容器中。不同的tomcat session是不共享的。这样 会话跟踪会失败。

二 使用redis共享session

tomcat 集群中,可以把session放到redis数据库中,解决session不共享的问题

进入cd /home/tomcat/apache-tomcat-7/lib路径下

把redis和tomcat配置的jar添加进去

jedis-2.5.2.jar

tomcat-redis-session-manage-tomcat7.jar
commons-pool2-2.2.jar

cd /home/tomcat/apache-tomcat-7/conf/

修改 context.xml文件

<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
  host="119.23.50.194"
  port="6379"
  database="0"
  password="sunkun1210"
  maxInactiveInterval="60" />

修改cd /home/tomcat/apache-tomcat-7/webapps/ROOT/ 目录下的index.jsp(tomcat欢迎页) 方便我们测试

119.23.50.194:9080 tomcat主页上加以下代码

  <%@ page session="true" %>

  <h1>tomcat9080</h1>
  session:<%=session.getId()%>

119.23.50.194:8080 tomcat主页上加以下代码

  <%@ page session="true" %>

  <h1>tomcat8080</h1>
  session:<%=session.getId()%>

大家可以点击测试,观察 tomcat的端口虽然编号 但是sessionId没变

Redis安装步骤

Nginx安装步骤

为了保证在集群系统中,会话数据能在redis进行存储。应该保证所有存放在会话范围内的所有属性都实现了java.io.Serializable接口。

原文地址:https://www.cnblogs.com/ssskkk/p/9250212.html

时间: 2024-08-08 07:14:07

Nginx+tomcat集群使用redis共享session的相关文章

Web应用优化之nginx+tomcat集群配置+redis管理session

1.nginx的安装 从官网下载一个nginx事务tar.gz版本,centos系统,安装好jdk 第一步解压 第二步:解压完成进入解压目录,执行./configure命令 需要安装gcc编译和pcre库,zlib库 yum -y install gcc yum install pcre-devel yum install zlib-devel ./configure完成后执行make install即可安装成功 2.集群配置流程 一.克隆2台CentOS虚拟机,并安装jdk+tomcat 二.

nginx+tomcat集群负载均衡(实现session复制)

转自:http://talangniao.iteye.com/blog/341512 架构描述 前端一台nginx服务器做负载均衡器,后端放N台tomcat组成集群处理服务,通过nginx转发到后面(注:没做动静分离,静态动态全部都转给tomcat) 优点:实现了可弹性化的架构,在压力增大的时候可以临时添加tomcat服务器添加到这个架构里面去 一,配置nginx 1,  下载包 Wget http://sysoev.ru/nginx/nginx-0.6.32.tar.gz ftp://ftp.

100513、nginx+tomcat集群+session共享(linux)

第一步:linux中多个tomcat安装和jdk安装(略) 第二步:nginx安装,linux中安装nginx和windows上有点不同也容易出错,需要编译,这里做介绍 一.安装依赖 gcc openssl-fips-2.0.2.tar.gz zlib-1.2.7.tar.gz pcre-8.21.tar.gz 下载linux版本的安装包,如果不下载安装包,可以在线安装命令: yum install gcc-c++ yum install -y pcre  pcre-devel yum inst

Java企业级电商项目实战 Tomcat集群与Redis分布式

本套课程包含:java电商项目实战课程 Tomcat集群视频教程 Redis项目实战课程课程目录1-1 课程导学1-2 大型Java项目架构演进解析1-3 一期课程与问答服务回顾1-4 一期项目结构和代码回顾1-5 课程使用系统及技术版本介绍(一期+二期)1-6 二期项目初始化第2章 Lombok框架集成及原理解析本章会对Lombok框架进行介绍,同时会讲解Lombok的原理.并手把手领着小伙伴们实战,引入Lombok以及IDE安装Lombok插件.然后会带着大家实战Coding,讲解@Data

Nginx+Tomcat 集群部署

1.Nginx + Tomcat 集群部署 简单配置 1 #user nobody; 2 worker_processes 4;#工作进程的个数 3 4 #error_log logs/error.log; 5 #error_log logs/error.log notice; 6 #error_log logs/error.log info; 7 8 #pid logs/nginx.pid; 9 10 11 events { 12 worker_connections 1024; #单个进程连

Java企业级电商项目架构演进之路 Tomcat集群与Redis分布式百度云实战分享

muke慕课实战课程分享QQ313675301 新增课程: Java企业级电商项目架构演进之路 Tomcat集群与Redis分布式百度云实战分享 后端开发: 1.高级java软件架构师实战培训视频教程2.大型SpringMVC,Mybatis,Redis,Solr,Nginx,SSM分布式电商项目视频教程3.Spark Streaming实时流处理项目实战4.Java校招面试 Google面试官亲授5.Java开发企业级权限管理系统6.Java大牛 带你从0到上线开发企业级电商项目7.Java

Java企业级电商项目架构演进之路Tomcat集群与Redis分布式

Java企业级电商项目架构演进之路Tomcat集群与Redis分布式网盘地址:https://pan.baidu.com/s/1taAooW3AhdGcdGSvOLqjkg 密码:nwip备用地址(腾讯微云):https://share.weiyun.com/5JdkNHX 密码:s9pm74 第1章 课程介绍[赠送一期源码+一期内容回顾]第2章 Lombok框架集成及原理解析第3章 Maven环境隔离应用场景及验证实战第4章 Tomcat集群演进详解及环境搭建第5章 Redis基础强化第6章

nginx+tomcat集群配置(1)---根目录设定和多后端分发配置

前言: 对于javaer而言, nginx+tomcat集群配置, 已然成了web应用部署的主流. 大公司如此, 小公司亦然. 对于个人开发者而言, 资源有限, 往往多个web应用混部于一台服务器(云主机), 如何隔离访问这些服务资源? 彼此又不影响呢? nginx来为你排忧解难, ^_^. 本文将介绍tomcat的简单配置和部署, 以及nginx作为反向代理, 如何分流. 基础架构: 不成文的约定: 1). 一个tomcat容器部署一个webapp应用实例 2). url根目录访问webapp

nginx+tomcat集群配置(4)--rewrite规则和多应用根目录设定思路

前言: nginx中有一块很重要的概念, 就是rewrite规则. 它会对URL进行修改, 然后进行内部的重定向. rewrite授予了nginx更多的自由, 使得后级服务的接入更加地方便. 本文将简单讲述nginx的rewrite规则和原理, 同时讲解下如何借助rewrite实现单tomcat实例/多Web App服务 对应的多域名根目录访问. 案列目标: 首先来谈一下之前对于多Web App服务对应多域名根目录访问的方案. 注: 一个域名对应一个tomcat实例, 一个tomcat实例只包含