全部运行在Tomcat下

第一台主机:192.168.200.131  安装nginx

修改hosts文件

[root@localhost ~]# vim /etc/hosts

192.168.200.131 nginx
192.168.200.130 node1
192.168.200.122 node2

 //将hosts文件发送给另外两台主机

[root@nginx ~]# scp /etc/hosts 192.168.200.122:/etc

[root@nginx ~]# scp /etc/hosts 192.168.200.130:/etc

//关闭防火墙及安全机制

[root@localhost ~]# iptables -F
[root@localhost ~]# systemctl stop firewalld
[root@localhost ~]# setenforce 0

[root@localhost ~]# hostname nignx  
[root@localhost ~]# bash                         //bash刷新
[root@nignx ~]#vim /usr/local/nginx/conf/nginx.conf

修改如下

#gzip  on;

 upstream tomcat_pool {                 //声明tomcat_pool,默认轮询
server 192.168.200.130: weight= max_fails= fail_timeout=10s;
//server 192.168.200.130:8080(节点端口)
//weight=1(权重)
//max_fails=1(最大故障数)
//fail_timeout=10s(故障超时)
server 192.168.200.122: weight= max_fails= fail_timeout=10s;
}

server {
     listen 80;
     server_name localhost;

charset utf-8;

access_log logs/host.access.log main;


location / {
    root html;
    index index.html index.htm;
    proxy_set_header Host $http_host;          //此处要添加host头

  //如果反向代理层的nginx不重写请求头中的host字段,将会导致请求失败,报400错误

proxy_pass http://tomcat_pool;             //做tomcat代理
}


[root@nginx ~]# nginx -t

[root@nginx ~]# killall -HUP nginx

测试:

结论:131主机nginx做tomcat反向代理依旧可以访问tomcat页面

轮询测试:介于122、130ip之间相互变化

因为130、122主机都做了session.jsp服务,此时131主机也可以进入测试页面

 Session绑定测试使得在122或130任意主机之间一个保持ip不变:

[root@nignx ~]#vim /usr/local/nginx/conf/nginx.conf

upstream tomcat_pool { 
ip_hash; //ip_hash表示绑定
server 192.168.200.130:8080 weight=1 max_fails=1 fail_timeout=10s;
 server 192.168.200.122:8080 weight=1 max_fails=1 fail_timeout=10s;
} 测试:

结论:这种方式极不稳定一旦122的主机服务中断,那么131服务必定从120跳转到130,这样会影响线上服务

解决方案一进行Session复制(在tomcat两台主机做nginx主机不用改变

Session复制测试(131主机):

可以利用IE浏览器测试,测试结果为session不变,node在变,ip也在变

解决方案2:

=================================================================================

第二台主机:192.168.200.130    安装tomcat

[root@localhost ~]# hostname node1
[root@localhost ~]# bash
[root@node1 ~]#

建立session.jsp的测试

[root@node1 ~]# vim /usr/local/tomcat8/webapps/ROOT/session.jsp

Session ID:<%= session.getId() %><BR>
SessionPort:<%= request.getServerPort() %>
//第一条与第二条:开头都是直接在网页上输出
//后面的函数都是会自动获取本机session的ID号,根据机器信息自动生成
<% out.println("This tomcat server 192.168.200.130");%>

启动tomcat

[root@node1 ~]# /usr/local/tomcat8/bin/shutdown.sh

[root@node1~]# /usr/local/tomcat8/bin/startup.sh

测试:

Session复制:

[root@node1 ~]# /usr/local/tomcat8/bin/shutdown.sh

[root@node1 ~]# /usr/local/tomcat8/bin/startup.sh

[root@node1 ~]# netstat -anpt | grep -E "8080|4000"    //有4000端口表示复制成功,没有4000端口表示复制失败,测试失败

Session复制测试:

Session复制测试结果应该为session不变,node在变,ip也在变(图为教师图)

本次实验失败

===============================================================================

第三台主机:192.168.200.122    安装tomcat

[root@localhost ~]# hostname node2
[root@localhost ~]# bash
[root@node2 ~]#

建立session.jsp的测试

[root@node2 ~]# vim /usr/local/tomcat8/webapps/ROOT/session.jsp

Session ID:<%= session.getId() %><BR>
SessionPort:<%= request.getServerPort() %>
//第一条与第二条:开头都是直接在网页上输出
//后面的函数都是会自动获取本机session的ID号,根据机器信息自动生成
<% out.println("This tomcat server 192.168.200.122");%>

启动tomcat

[root@node2~]# /usr/local/tomcat8/bin/shutdown.sh

[root@node2 ~]# /usr/local/tomcat8/bin/startup.sh

测试:

Session复制:

[root@node2~]# /usr/local/tomcat8/bin/shutdown.sh

[root@node2 ~]# /usr/local/tomcat8/bin/startup.sh

[root@node2~]# netstat -anpt | grep -E "8080|4000"            //有4000端口表示复制成功没有4000端口表示失败

Session复制测试结果应该为session不变,node在变,ip也在变(图为教师图)

本次实验失败

Session服务器之Session复制!的更多相关文章

  1. Session服务器之Memcached与Redis

    安装Memcached[root@nginx ~]# yum -y install libevent memcached 指定用户大小等信息,工作环境中常指定大小一般为4到8G,此信息测试使用.[ro ...

  2. Session服务器之Redis

    Session服务器之Redis Redis与Memcached的区别内存利用率:使用简单的key value (键值对)存储的话,Mermcached 的内存利用率更高,而如果Redis采用hash ...

  3. Session服务器之Memcached

    材料:两台Tomcat(接Session复制一起做) 第一台Tomcat:IP为130 [root@localhost ~]# yum install libevent memcached -y    ...

  4. Apache + Tomcat + mod_jk实现集群服务及session共享

    实现效果:用apache 分发请求到tomcat中的对应的项目 原理:

  5. 【转载】HTTP Session 内存到内存复制的拓扑结构

    http://www.oschina.net/question/129540_23215 HTTP 协议本身是“连接 - 请求 - 应答 - 关闭连接”的模式,是一种无状态协议:然而随着 web 动态 ...

  6. 客户端session与服务端session

    会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话.常用的会话跟踪技术是Cookie与Session.Cookie通过在客户端记录信息确定用户身份,Session通过在服务器端 ...

  7. ASP.NET状态服务及session丢失问题解决方案总结

    原文:ASP.NET状态服务及session丢失问题解决方案总结[转载] asp.net Session的实现: asp.net的Session是基于HttpModule技术做的,HttpModule ...

  8. 转:客户端session与服务端session

    会话(Session)跟踪是Web程序中常用的技术,用来 跟踪用户的整个会话 .常用的会话跟踪技术是Cookie与Session. Cookie通过在客户端记录信息确定用户身份 , Session通过 ...

  9. 【转】Android 服务器之SFTP服务器上传下载功能

    原文网址:http://blog.csdn.net/tanghua0809/article/details/47056327 本文主要是讲解Android服务器之SFTP服务器的上传下载功能,也是对之 ...

随机推荐

  1. DataTable、DataRow、DataColumn用法

    转载csdner 发布于2018-08-17 17:03:30 阅读数 4375  收藏   DataSet 表示数据在内存中的缓存. 属性 Tables  获取包含在 DataSet 中的表的集合. ...

  2. Codeforces Round #598 (Div. 3) C. Platforms Jumping

    There is a river of width nn. The left bank of the river is cell 00 and the right bank is cell n+1n+ ...

  3. Django流程-以登录功能为例

    Django流程-以登录功能为例 一.注意点 1.新创建的app一定要先去settings.py注册 简写:'app01' 完整:'app01.apps.App01Config' 2.启动Django ...

  4. 无源汇有上下界可行流(ZQU 1590)

    无源汇有上下界可行流(也就是循环流) 模型:一个网络,求出一个流,使得每条边的流量必须>=Li且<=Hi, 每个点必须满足总流入量=总流出量(流量守恒)(这个流的特点是循环往复,无始无终) ...

  5. 随机获取list或set或map中的一个元素

    转自:https://m.2cto.com/kf/201507/412937.html import java.util.HashSet;import java.util.List;import ja ...

  6. 实战【docker 镜像制作与使用】

    一.制作docker 镜像 使用spring boot 构建一个简单的web 项目,返回 “Hello,World ”字符串,使用 Maven 打成 jar 包,使用的Linux 环境是 Centos ...

  7. django 模版查找路径

    路径的配置,模版上下文的配置等.模版路径可以在两个地方配置. 1.'DIRS':这是一个列表,在这个列表中可以存放所有的模版路径,以后在视图中使用render或者render_to_string渲染模 ...

  8. Java最新面试问答整理

    Q:JDK和JRE区别? JDK是整个JAVA的核心,包括了Java运行环境JRE,一堆Java工具和Java基 础的类库.通过JDK开发人员将源码文件(java文件)编译成字节码文件(class文 ...

  9. php将数据写入另外一个文件

    有时候,为了验证PHP的运行过程或者了解代码中的变量的使用情况,需要将变量写到另外一个文件中,方便我们查看.最近也是经常用到file_put_contents这个函数,因为只是试验用,暂时还不需要考虑 ...

  10. 如何让DOS命令在新窗口打开

    可以调用别外的批处理如 start a.batstart b.batstart c.bat 新建a.bat.B.BAT.C.CAT,在这几个批处理中输入你的命令. 以上我自己测试通过.