nginx 多tomcat 单memcached记录 session共享

版本
nginx/1.21.6;
tomcat-8.5.32;
memcached 1.6.14;
所需jar包:

链接: link

tomcat 修改为不同端口
tomcat/conf/server.xml

下面展示一些 内联代码片

// An highlighted block
<Server port="8005" shutdown="SHUTDOWN">
<Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
               <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

conf/context.xml

// An highlighted block
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
                memcachedNodes="n1:192.168.1.162:11211"
                lockingMode="auto"
                sticky="false"
                failoverNodes=""
                sessionBackupAsync="false"
         sessionBackupTimeout= "1000"  
         copyCollectionsForSerialization="true"
         requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
                transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"/>

nginx配置nginx.conf

// An highlighted block
		upstream tcsv {
      	server 127.0.0.1:8060;
      	server 127.0.0.1:8084;
    }


    server {
        listen       8888;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        #location / {
        #    root   html;
        #    index  index.html index.htm;
        #}

			location / {
	     	proxy_pass http://tcsv;//这里和upstream处一样;加项目名之后会导致sessionID一直变
        #    root   html;
        #    index  index.html index.htm;
       }

nginx启动,终止,重启

nginx
nginx -s stop
nginx -s reload

jsp内容

// An highlighted block
<%@ page language="java" contentType="text/html; charset=UTF-8"
		 pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
	<title>Cluster Web Test</title>
</head>
<body>
<h1>sessionID:<%=session.getId() %></h1>
<h1>长度:<%=session.getId().length() %></h1>
    <p>this is tomcat 1</p>
</body>
</html>

memcached启动
终端
memcached -d -p 11211 -u nobody -c 1024 -m 64

memcached停止

ps -ef | grep memcache
kill 97052

多memcached 节点
memcached
memcached -d -p 11211 -u nobody -c 1024 -m 64
memcached -d -p 11212 -u nobody -c 1024 -m 64

context.xml 配置

// An highlighted block
 <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
                memcachedNodes="n1:192.168.1.162:11211,n2:192.168.1.162:11212"
                lockingMode="auto"
                sticky="false"
                failoverNodes="n2"
                sessionBackupAsync="false"
         sessionBackupTimeout= "1000"  
         copyCollectionsForSerialization="true"
         requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
                transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"/>
另一个tomcat/conf/context.xml配置
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
                memcachedNodes="n1:192.168.1.162:11211,n2:192.168.1.162:11212"
                lockingMode="auto"
                sticky="false"
                failoverNodes="n1"
                sessionBackupAsync="false"
         sessionBackupTimeout= "1000"  
         copyCollectionsForSerialization="true"
         requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
                transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"/>

应该是配置没有设置正确,刷新页面的时候tomcat会报错:

24-Mar-2022 10:46:55.560 信息 [msm-2ndary-backup-thread-3] de.javakaffee.web.msm.LockingStrategy$OnAfterBackupSessionTask.call Could not store secondary backup of session FB3E8CB8BB5C7A82BD507E51635858AA-n1
 java.lang.IllegalArgumentException: No node found for key bak:FB3E8CB8BB5C7A82BD507E51635858AA-n1 (nodeId: null, known nodeIds: [n2, n1])

但是sessionid不会变(研究中)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1,在tomcat中找到文件apache-tomcat-6.0.37\conf\context.xml 加入内部 <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" memcachedNodes="n1:192.168.1.65:11211" requestUriIgnorePattern=".*\.(png|gif|jpg|css|js)$" sessionBackupAsync="false" sessionBackupTimeout="100" transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory" copyCollectionsForSerialization="false" /> 加入之后的content.xml的内容为 <?xml version='1.0' encoding='utf-8'?> <!-- Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to You under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. --> <!-- The contents of this file will be loaded for each web application --> <Context> <!-- Default set of monitored resources --> <WatchedResource>WEB-INF/web.xml</WatchedResource> <!-- Uncomment this to disable session persistence across Tomcat restarts --> <!-- <Manager pathname="" /> --> <!-- Uncomment this to enable Comet connection tacking (provides events on session expiration as well as webapp lifecycle) --> <!-- <Valve className="org.apache.catalina.valves.CometConnectionManagerValve" /> <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" memcachedNodes="n1:192.16
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值