阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Nginx-会话一致性解决(sesion一致)

119次阅读
没有评论

共计 2787 个字符,预计需要花费 7 分钟才能阅读完成。

由于 Tomcat 使用的为集群, 通过 nginx 访问时轮询不同的 tomcat, 使得 session 无法统一, 所以将 session 单独抽取出来做共享 session。

此 tomcat 版本为 7.0.61.tar.gz  刚开始用 7.0.75 对他来说版本太高了, 一直包异常!!!!!!

首先打开两台 tomcat, 使用 nginx 进行反向代理, 修改 CATALINA_HOME/conf/server.xml

#tocmat01 中配置
<Engine name=Ca.. def.. jvmRoute=tomcat1>
#tomcat02 中配置
<Engine name=Ca.. def.. jvmRoute=tomcat2>
#tomcat03 中配置
<Engine name=Ca.. def.. jvmRoute=tomcat3>

此时通过页面取值

<html lang="en">
        <h1>tomcat_01</h1>
sessionId: <%=session.getId()%>
sessionIP: <%=request.getServerName()%>
</html>

可在浏览器中看到 sessionId 的变化

关于 session 共享有四种方案

1), tomcat 广播, 对系统资源占用较大, 占用 io 流, 不推荐使用

2), 使用 memcache

3), 使用 redis, 安装第三方库, 

4), 使用 tengine 的 cookie 一致性解决

本文只讲后面三种方式

 2, 使用 memcached 作为 session 管理

2.1) 安装 memcached

yum -y install memcached

2.2) 测试 memcached 是否安装成功, 使用 telnet, 没有的话 yum 安装

telnet localhost 11211

会显示: 

Nginx- 会话一致性解决 (sesion 一致)

然后: 

set abc 0 0 5
12345

出现 STORED 表示 memcached 安装成功

2.3) tomcat 下安装 jar, 拷贝到 CATALINA_HOME/lib 目录下, 

Nginx- 会话一致性解决 (sesion 一致)

2.4) 更改 tomcat 配置

vim ./conf/context.xml

<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" 
memcachedNodes="n1:192.168.208.102:11211" 
sticky="false" 
lockingMode="auto"
sessionBackupAsync="false"
sequestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
sessionBackupTimeout="1000" transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory" 
/>

之后启动 tomcat, 既可以看到 sessionID 已经不变了

 3, 使用 redis 解决 session 一致性问题

 配置和 memcached 基本类似

3.1) 安装 redis

yum install redis

启动

service redis start

3.2) 修改 reids.conf 中的 bind, 否则只能使用 localhost 访问

vim /etc/redis.conf


bind 192.168.208.102

3.3), 在 CATALINA_HOME/conf/context.xml 中添加配置

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

3.4) 将 redis 和 tomcat 的 session-manager jar 包导入

Nginx- 会话一致性解决 (sesion 一致)

此时启动 tomcat, 就可以完成 session 一致性问题了

4, 使用 tengine 的会话保持功能实现

tengine 提供了 cookie 保持功能, 即客户端访问一台服务器后, 始终指向该台服务器, 相当于粘滞功能

Nginx- 会话一致性解决 (sesion 一致)

此种情况, 分配的那台 tomcat 挂了以后, 就不能狗保持回话一致了, 因此并不为一种可靠的解决方案。

此外, 使用 memcached 或 redis 时, 如果不想安装插件, 可在代码中直接操作缓存来存储和取出数据, 相当于 session, 为一种比较可靠的一致性解决方案

CentOS 7 下 Nginx 服务器的安装配置  http://www.linuxidc.com/Linux/2017-04/142986.htm

CentOS 上安装 Nginx 服务器实现虚拟主机和域名重定向  http://www.linuxidc.com/Linux/2017-04/142642.htm

CentOS 6.8 安装 LNMP 环境(Linux+Nginx+MySQL+PHP)http://www.linuxidc.com/Linux/2017-04/142880.htm

Linux 下安装 PHP 环境并配置 Nginx 支持 php-fpm 模块  http://www.linuxidc.com/Linux/2017-05/144333.htm

Nginx 服务的 SSL 认证和 htpasswd 认证  http://www.linuxidc.com/Linux/2017-04/142478.htm

Ubuntu 16.04 上启用加密安全的 Nginx Web 服务器  http://www.linuxidc.com/Linux/2017-07/145522.htm

Linux 中安装配置 Nginx 及参数详解  http://www.linuxidc.com/Linux/2017-05/143853.htm

Nginx 日志过滤 使用 ngx_log_if 不记录特定日志 http://www.linuxidc.com/Linux/2014-07/104686.htm

CentOS 7.2 下 Nginx+PHP+MySQL+Memcache 缓存服务器安装配置  http://www.linuxidc.com/Linux/2017-03/142168.htm

CentOS6.9 编译安装 Nginx1.4.7  http://www.linuxidc.com/Linux/2017-06/144473.htm

Nginx 的详细介绍 :请点这里
Nginx 的下载地址 :请点这里

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-07/145760.htm

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计2787字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中