MemCache在tomcat中的负载均衡和session交叉存放

一、安装jdk

1.下载软件,并解压到指定目录/usr/local/

[root@server1 ~]# tar zxf jdk-7u79-linux-x64.tar.gz -C /usr/local/
[root@server1 ~]# tar zxf apache-tomcat-7.0.37.tar.gz -C /usr/local/

在这里插入图片描述
2.为了后面使用方便,切换到/usr/local目录下制作软链接

(1)制作软链接

[root@server1 ~]# cd /usr/local/
[root@server1 local]# ls
[root@server1 local]# ln -s apache-tomcat-7.0.37 tomcat
[root@server1 local]# ll

在这里插入图片描述
(2)制作软链接之后可以自动补齐,如下所示:

[root@server1 local]# java/
bin/     db/      include/ jre/     lib/     man/ 

在这里插入图片描述
3.配置java的环境变量,并使其生效

[root@server1 local]# vim /etc/profile
在文章最后添加:
 80 export JAVA_HOME=/usr/local/java
 81 export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
 82 export PATH=$PATH:$JAVA_HOME/bin
[root@server1 local]# source /etc/profile     # 重新加载配置文件

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
4.编辑脚本,检测jdk环境是否正确

[root@server1 ~]# vim  test.java
  1 public class test{
  2         public static void main(String[] args)
  3         { 
  4                 System.out.println("Hello World!");
  5         }
  6 }

[root@server1 ~]# javac test.java      #javac编译.java脚本
[root@server1 ~]# java test       # 运行脚本
Hello World!    # 运行结果

在这里插入图片描述
在这里插入图片描述

二、安装tomcat实现负载均衡

1.查看各目录下的文件,打开tomcat,并查看端口

[root@server1 ~]# cd /usr/local/tomcat/
[root@server1 tomcat]# ls
[root@server1 tomcat]# cd bin/
[root@server1 bin]# ls
[root@server1 bin]# ./startup.sh     ###开启tomcat
[root@server1 bin]# netstat -tnlp    ###查看端口,tomcat的端口默认为8080

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
2.编辑openresty的配置文件,如下所示:

[root@server1 ~]# cd /usr/local/openresty/nginx/conf/
[root@server1 conf]# vim nginx.conf
 72         location ~ \.jsp$ {
 73             proxy_pass   http://127.0.0.1:8080;
 74         }
[root@server1 sbin]# pwd
/usr/local/lnmp/openresty/nginx/sbin
[root@server1 sbin]# ./nginx -s reload

在这里插入图片描述
在这里插入图片描述
3.重新加载服务,如下所示:

[root@server1 conf]# cd /usr/local/lnmp/openresty/nginx/sbin
[root@server1 sbin] ./nginx -s reload

在这里插入图片描述
4.进入tomcat的发布目录,编辑文件,测试tomcat是否安装正确

[root@server1 ROOT]# pwd
/usr/local/tomcat/webapps/ROOT
[root@server1 ROOT]# vim time.jsp 
  1 the time is:<%=new java.util.Date() %>
[root@server1 ROOT]# cat time.jsp

在这里插入图片描述
在这里插入图片描述
5.测试

在浏览器中输入172.25.10.1/time.jsp网址,出现的页面是刚所写的时间;输入172.25.10.1/index.jsp网址,出现的页面是tomcat的官网,但是并没有显示图像,而输入172.25.10.1:8080添加端口后图像显示,这是因为此时的显示并不是通过tomcat来显示的,而是通过本机的8080端口显示的。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
6.将server1上配置的好的tomcat和jdk,发送到server2上

[root@server1 ROOT]# cd /usr/local
[root@server1 local]# ll
[root@server1 local]# scp -r  apache-tomcat-7.0.37 jdk1-1.7.0_79 server2:/usr/local

在这里插入图片描述
7.在server2上同样配置java环境变量,如下所示:

[root@server2 ~]# ls
[root@server2 ~l]# vim /etc/profile
 80 export JAVA_HOME=/usr/local/java
 81 export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
 82 export PATH=$PATH:$JAVA_HOME/bin
[root@server2 ~]# source /etc/profile

在这里插入图片描述
在这里插入图片描述
8.使server2的环境配置生效并制作软连接

[root@server2 local]# ln -s apache-tomcat-7.0.37 tomcat
[root@server2 local]# source /etc/profile
[root@server2 local]# java
[root@server2 local]# java -version

在这里插入图片描述
在这里插入图片描述
9.开启server2的服务并查看端口,如下所示:

[root@server2 local]# cd tomcat/
[root@server2 tomcat]# ls
[root@server2 tomcat]# cd bin/
[root@server2 bin]# ls
[root@server2 bin]# ./startup.sh
[root@server2 bin]# netstat -tnlp                  

在这里插入图片描述
在这里插入图片描述
10.在server1上编辑nginx的配置文件,实现server1和server2tomcat的负载均衡

[root@server1 ~]# cd /usr/local/openresty/nginx/conf/
[root@server1 conf]# vim nginx.conf
 17 http {
 18         upstream tomcat{
 19             server 172.25.10.1:8080;    # 后端服务器之一
 20             server 172.25.10.2:8080;    # 后端服务器之一
 21         }

 72         location ~ \.jsp$ {
 73             proxy_pass   http://tomcat;
 74         }

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
11. 重新加载server1的服务并查看端口,如下所示:
在这里插入图片描述
12.编写负载均衡的测试页内容

[root@server1 ~]# cd /usr/local/tomcat/webapps/ROOT
[root@server1 ROOT]# vim time.jsp
server1 the time is:<%=new java.util.Date() %>

[root@server2 ~]# cd /usr/local/tomcat/webapps/ROOT/
[root@server1 ROOT]# vim time.jsp
server2 the time is:<%=new java.util.Date() %>

在这里插入图片描述
在这里插入图片描述
13.测试

在浏览器中输入以下网址http://172.25.10.1/time.jsp,发现每次刷新,就会重新显示页面(server1和server2出现轮循)
在这里插入图片描述
在这里插入图片描述
三、在tomcat中实现session共享

为什么要使用session

  • 为了对数据的保存更加牢靠,我们选择交叉存放session的方法,所谓交叉存放就是将访问tomcat1上的数据存放在memcache2中,将访问tomcat2上的数据存放在memcache1中,这样存放,当某个tomcat服务断了之后,访问它的客户session并不会消失,而是存放在了对立的memcache,如果存放session的memcache坏了,那么它的数据会立即切换到另一个memcached中,是非常方便的。

1.重新编写测试页内容,从物理机上拷贝一个信息提交页面到tomcat发布目录

[root@server1 ~]# scp root@172.25.10.250:/home/kiosk/Desktop/test.jsp .
[root@server1 ~]# ls
[root@server1 ~]# mv test.jsp /usr/locak/tomcat/webapps/ROOT/
[root@server1 ~]# cd /usr/local/tomcat/webapps/ROOT/
[root@server1 ROOT]# ls

在这里插入图片描述
内容如下:
在这里插入图片描述
在这里插入图片描述
2.将server1的信息提交文件发送给server2,如下所示:

[root@server1 conf]# cd/usr/local/tomcat/webapps/ROOT/
[root@server1 ~]# ls
[root@server1 ~]# pwd
[root@server1 ~]#  scp test.jsp server2:/usr/local/tomcat/webapps/ROOT/

在这里插入图片描述
3.测试
浏览器输入http://172.25.10.1/test.jsp 显示新的测试页面,在server2上传数据westos1
在这里插入图片描述
提交之后,数据信息会存到server2上,再提交westos2的信息
在这里插入图片描述
提交之后,数据信息会存到server1上
在这里插入图片描述
总结:每次提交数据server info的id会改变,而且每一次提交的数据会被覆盖,这是不合理的,因此需要添加sticky模块

为了解决这一问题,实现数据不交换,上传信息到同一个后端服务器,我们需要进行下面的操作:

1.上传并解压安装包nginx-1.10.1.tar和nginx的sticky安装包

[root@server1 ~]# scp root@172.25.10.250:/home/kiosk/Desktop/nginx-sticky-module-ng.tar.gz .
[root@server1 ~]# scp root@172.25.10.250:/home/kiosk/Desktop/nginx-1.10.tar.gz .
[root@server1 ~]# ls
[root@server1 ~]# tar zxf nginx-1.10.1.tar.gz
[root@server1 ~]# tar zxf nginx-sticky-module-ng.tar.gz 

在这里插入图片描述
2.去掉nginx的版本号

[root@server1 ~]# cd nginx-1.10.1
[root@server1 nginx-1.10.1]# vim src/core/nginx.h
14 #define NGINX_VER          "nginx/"        ##删掉后面的部分

在这里插入图片描述
在这里插入图片描述
3.关闭debug日至

[root@server1 nginx-1.10.1]# vim auto/cc/gcc
178 # debug
179 #CFLAGS="$CFLAGS -g"    ##注释掉这一行

在这里插入图片描述
在这里插入图片描述

4.把原来的openresty下的nginx关掉

[root@server1 ~]# cd /usr/local/openresty/nginx/sbin/    
[root@server1 sbin]# ./nginx -s stop

在这里插入图片描述
5.进入解压目录,进行编译,在后面添加sticky模块

[root@server1 nginx-1.10.1]# ./configure --prefix=/usr/local/lnmp/nginx --with-http_ssl_module --with-http_stub_status_module --with-threads --with-file-aio --add-module=/root/nginx-sticky-module-ng 
[root@server1 nginx-1.10.1]# make && make install

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
6.编写新的nginx配置文件(把原来openresty下的nginx配置文件直接复制过来即可)

[root@server1 sbin]# cd /usr/local/lnmp/nginx/conf/ 
[root@server1 conf]# cp /usr/local/openresty/nginx/conf/nginx.conf . 
cp: overwrite `./nginx.conf'? y 
[root@server1 conf]# vim nginx.conf 
17 http { 
18            upstream tomcat{ 
19                sticky; ##添加 
20                server 172.25.10.1:8080; 
21                server 172.25.10.2:8080; 
22           } 
23      include mime.types; 
24      default_type application/octet-stream;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
7.重新加载使其生效

[root@server1 conf]# ../sbin/nginx -s reload

在这里插入图片描述
8.测试

在浏览器输入172.25.10.1/test.jsp
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
总结:可以看到现在上传的数据都被存放,但是每一次提交数据都是在server1上

为了解决这一问题,我们还需进行下面的操作,如下所示:

实现交叉互存:

1.在server2上同样要安装memcached,如下所示:

[root@server2 bin]# yum install -y memcached

在这里插入图片描述
在这里插入图片描述
2. 上传jar中的包到server1和server2,如下所示:

[root@server1 ~]# cd /usr/bin/local/tomcat/lib
[root@server1 lib]# scp root@172.25.10.250:/home/kiosk/Desktop/jar/*.  
[root@server1 lib]# ls
[root@server1 lib]# rm -rf memcached-session-manager-tc6-1.6.3.jar     
[root@server1 lib]# ls

在这里插入图片描述

[root@server2 ~]# cd /usr/bin/local/tomcat/lib
[root@server2 lib]# scp root@172.25.10.250:/home/kiosk/Desktop/jar/*.  
[root@server2 lib]# ls
[root@server2 lib]# rm -rf memcached-session-manager-tc6-1.6.3.jar     
[root@server2 lib]# ls

在这里插入图片描述
3.分别编辑server1和server2的xml文件,如下所示:

[root@server1 bin]# cd /usr/local/tomcat/conf/
[root@server1 conf]# vim context.xml 
   34 <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" 
   35 memcachedNodes="n1:172.25.10.1:11211,n2:172.25.10.2:11211" 
   36 failoverNodes="n1" 
   37 requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$" 
   38 transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"  
   39 />

在这里插入图片描述
在这里插入图片描述

[root@server2 bin]# cd /usr/local/tomcat/conf/
[root@server2 conf]# vim context.xml 
   34 <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" 
   35 memcachedNodes="n1:172.25.10.1:11211,n2:172.25.10.2:11211" 
   36 failoverNodes="n2" 
   37 requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$" 
   38 transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"  
   39 />

在这里插入图片描述
在这里插入图片描述
4.分别重启server1和server2的tomcat,以及server2的meecache服务,如下所示:

[root@server1 conf]# cd/uar/local/tomcat/bin/
[root@server1 bin]# ./shutdown.sh
[root@server1 bin]# ./startup.sh      

在这里插入图片描述

[root@server2 conf]# cd/uar/local/tomcat/bin/
[root@server2 bin]# ./shutdown.sh
[root@server2 bin]# ./startup.sh      
[root@server2 bin]# /etc/init.d/memcache start
[root@server2 bin]# /etc/init.d/memcache status

在这里插入图片描述
注意:tomcat的重启用./shutdown.sh和./startup.sh

5.测试:

进入浏览器,刷新页面,显示在server1上,在server1上提交信息(feng2、feng3)
在这里插入图片描述
在这里插入图片描述
发现在server2上缓存到了server1的信息
在这里插入图片描述

关闭server2,进入server1文件查看,如下所示:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

weixin_42566251

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值