nginx+tpmcat+redis实现session共享
nginx+tpmcat+redis实现session共享
版本:
nginx nginx-1.8.0.tar.gz
tomcat apache-tomcat-7.0.78.tar.gz
redis redis-stable 4.0.1
安装包下载地址:链接:http://pan.baidu.com/s/1gfQqpPL 密码:xwpv
PS:redis在此用的是单节点,实际应用redis应该是集群形式
安装redis 网上教程有很多,最后需要注意的是配置redis外网访问
设置redis外网访问
配置文件中找到bind 127.0.0.1注释掉
再查找protected-mode yes 把yes修改为no
在查找daemonize 设置为no
/sbin/iptables -I INPUT -p tcp --dport 6379 -j ACCEPT 修改防火墙,使6379端口可以访问
/etc/rc.d/init.d/iptables save 保存防火墙修改命令
tomcat7安装
cd /usr/local/tomcat7
将安装包放入该目录下
tar xzf apache-tomcat-7.0.78.tar.gz解压文件
cd /usr/local/tomcat7
./bin/startup.sh启动tomcat
vi /etc/rc.d/rc.local 将/usr/local/tomcat7/apache-tomcat-7.0.78.tar.gz/bin/startup.sh放置在最下面 设置开机启动
/etc/init.d/iptables stop关闭防火墙 外网可以访问tomcat欢迎界面
相关命令:
关闭防火墙指令:/etc/init.d/iptables stop
永久关闭防火墙指令:chkconfig iptables off
开启防火墙指令:/etc/init.d/iptables start
永久开启防火墙指令:chkconfig iptableson
查看防火墙状态:/etc/init.d/iptables status
修改tomcat/conf/context.xml文件在</context>上面添加
<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve"/>
<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
host="192.168.4.53" #这里是redis的ip地址
port="6379" #这里是redis的端口号
database="0" #这里是redis的数据库选择
maxInactiveInterval="60"/> #设置session的最大保存时间
PS(如果redis有密码。需要再加一行password:"123456")
在tomcat/bin下面导入jar包 jar包地址为:链接:http://pan.baidu.com/s/1o881d5g 密码:jwee
创建示例程序,分别放到对应ip的tomcat下面,启动tomcat
<body>
这是ip192.168.4.51的界面
<%= session.getId() %>
</body>
<body>
这是ip192.168.4.53的界面
<%= session.getId() %>
</body>
访问http://192.168.4.53:8080//SessionTest/index.jsp http://192.168.4.51:8080//SessionTest/index.jsp
都可以看到对应的界面,但是IP不一样
配置nginx
1.安装教程不再讲述,安装教程:链接:http://pan.baidu.com/s/1kUEwCSZ 密码:4b7d
2.上述教程需要的配置文件地址:链接:http://pan.baidu.com/s/1jIqYugu 密码:dvnx
3.配置文件nginx.conf文件
upstream myServer {
server 192.168.4.51:8080;
server 192.168.4.53:8080;
} #配置tomcat的IP地址和端口号
#gzip on;
#监听88 端口
server {
listen 88;
#定义要使用的域名
server_name localhost;
#charset koi8-r;
#设定本虚拟主机的访问日志
#access_log logs/host.access.log main;
#配置前缀 即要转发到的ip+port
location / {
proxy_pass http://myServer; #引用upstream myServer
# root html; #注释nginx的欢迎界面
# index index.html index.htm;
}
nginx的IP地址为192.168.4.52 端口为88
nginx配置成功之后。http://192.168.4.52:88,可以访问到tomcat的欢迎界面
http://192.168.4.52:88/SessionTest/index.jsp 刷新,可以看到IP会变化,但是session ID的值一直保持不变,实现session共享。
本篇CSDN地址:http://blog.csdn.net/chenjian123654/article/details/77895336
参考资料地址:
http://blog.csdn.net/zhanghongjie0302/article/details/50550289
http://oceanszf.blog.51cto.com/6268931/1752641
http://zihai367.iteye.com/blog/2271371
http://blog.csdn.net/qq_16216221/article/details/72599016
nginx+tpmcat+redis实现session共享的更多相关文章
- Nginx+tomcat+redis实现session共享
Nginx+tomcat+redis实现session共享 1,安装nginx,使用yum -y install nginx 这是epel源中的,需要安装epel源. 2,配置nginx. 在ngin ...
- nginx+tomcat+redis完成session共享(转载)
转载:http://blog.csdn.net/grhlove123/article/details/48047735 tomcat7下基于redis的session共享所需jar包: http:// ...
- nginx+tomcat+redis完成session共享
本文记录nginx+redis+tomcat实现session共享的过程 nginx安装:http://blog.csdn.net/grhlove123/article/details/4783467 ...
- Nginx+IIS+Redis 处理Session共享问题 1
最近遇到一个棘手的问题,微信公众平台的前端站点session老是丢失,我们是走的微信网页授权,授权后获取用户openid,丢失后没有openid后续的操作全白搭了,因为没了openid只能判断为客户不 ...
- Nginx+IIS+Redis 处理Session共享问题 2
接下来主要说下利用nginx来测试 两台Windows server 1.10.120.131.210 - 端口84部署demo 2.10.120.131.211 - 端口84部署demo ngi ...
- Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享
Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享 ============================= 蕃薯耀 2017年11月27日 http: ...
- Nginx+Tomcat搭建集群,Spring Session+Redis实现Session共享
小伙伴们好久不见!最近略忙,博客写的有点少,嗯,要加把劲.OK,今天给大家带来一个JavaWeb中常用的架构搭建,即Nginx+Tomcat搭建服务集群,然后通过Spring Session+Redi ...
- nginx+tomcat实现集群,redis实现session共享,软连接实现文件共享:http://blog.csdn.net/hua1586981/article/details/78132710
转载 2017年02月08日 16:52:41 730 相信很多人都听过nginx,这个小巧的东西慢慢地在吞食apache和IIS的份额.那究竟它有什么作用呢?可能很多人未必了解. 说到反向代理,可能 ...
- Nginx集群配置与redis的session共享策略
一.什么是Nginx? Nginx (engine x) 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器.Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Ramb ...
随机推荐
- python学习-判断是否是IP地址
1.使用正则表达式 首先分析IP地址的组成,十进制的合法IP地址由32位数字组成 使用.分割开 每个分组可出现的情况: 第一个分组: 1-9:一位数字 10-99:两位数字 100-199:三位数字且 ...
- ELK-logstash-6.3.2部署
Logstash 是一款强大的数据处理工具,它可以实现数据传输,格式处理,格式化输出,还有强大的插件功能,常用于日志处理. 1. logstash部署 [yun@mini04 software]$ p ...
- jQuery插件slider实现图片轮播
1:引入相应的js文件 jquery.SuperSilder.js 2:HTML: 结构 注:此地加载图片的代码也可以从后台库中读取图片的集合列表,然后通过循环的方式显示出来 3:CSS 样式定义左 ...
- 合并多个Excel文件
这条分享来自百度经验https://jingyan.baidu.com/article/e6c8503cb6ed7ee54e1a1811.html
- 「SNOI2019」通信
题目 还好我没生在陕西啊 首先发现这个题不能\(dp\),数据范围不大,好像一种网络流的样子啊 哎等等,这样向后面连边不是一个\(DAG\)吗,这不是最小权路径覆盖的板子吗 于是我们套路的拆点,对于一 ...
- E - Matrix Power Series (矩阵数列)
然后,怎么来求这个前k项的和,我把式子推一下 当k为奇数的时候直接SK-1+AK 就又化为偶数的情况了.代码如下: #include<iostream> #include<cstr ...
- php结合redis高并发下,悲观锁解决数据二次写入
悲观锁 在悲观锁的情况下,为了保证事务的隔离性,就须要一致性锁定读.读取数据时给加锁,其他事务无法改动这些数据.改动删除数据时也要加锁,其他事务无法读取这些数据. 在做数据缓存的时候,通常都是把数据从 ...
- 判断MS SQLSERVER临时表是否存在
drop table #tempcitys select * into #tempcitys from hy_citys 上面的语句第一次运行的时候就肯定出错了,但第二次就不会.因为select * ...
- day10,11-Python 基本数据类型介绍之数字与字符串(看看就好)
数字:int #字符串转换整型 a = "123" print(type(a),a) b = int(a) print(type(b),b) b = b + 1000 print( ...
- SpringMVC——消息转换器HttpMessageConverter(转)
文章转自http://blog.csdn.net/cq1982/article/details/44101293 概述 在SpringMVC中,可以使用@RequestBody和@ResponseBo ...