共计 2787 个字符,预计需要花费 7 分钟才能阅读完成。
由于 Tomcat 使用的为集群, 通过 nginx 访问时轮询不同的 tomcat, 使得 session 无法统一, 所以将 session 单独抽取出来做共享 session。
此 tomcat 版本为 7.0.61.tar.gz 刚开始用 7.0.75 对他来说版本太高了, 一直包异常!!!!!!
首先打开两台 tomcat, 使用 nginx 进行反向代理, 修改 CATALINA_HOME/conf/server.xml
此时通过页面取值
<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
会显示:
然后:
set abc 0 0 5
12345
出现 STORED 表示 memcached 安装成功
2.3) tomcat 下安装 jar, 拷贝到 CATALINA_HOME/lib 目录下,
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 包导入
此时启动 tomcat, 就可以完成 session 一致性问题了
4, 使用 tengine 的会话保持功能实现
tengine 提供了 cookie 保持功能, 即客户端访问一台服务器后, 始终指向该台服务器, 相当于粘滞功能
此种情况, 分配的那台 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