Jetty集群配置Session存储到MySQL、MongoDB

本文详细介绍了如何在Jetty集群环境中配置Session存储,包括将Session保存到MySQL和MongoDB,以实现Session在多台服务器间的共享。通过XML配置和Java代码解析,展示了具体的实现步骤和技术要点。
摘要由CSDN通过智能技术生成

在Web开发中,Session表示HTTP服务器与客户端(例如浏览器)的“会话”,每个客户端会有其对应的Session保存在服务器端,通常用来保存和客户端关联的一些信息,例如是否登录、购物车等。

Session一般情况下是保存在服务器内存中。如果服务器重启,Session就会丢失。另外,如果是集群环境,Web应用部署在多台服务器上,Session如果保存在各自的服务器上,就无法共享了。

针对这个问题,Jetty服务器提供了用于集群环境下的Session实现方式,即通过多台Jetty服务器连接到同一个Session数据库来实现Session共享。

1、配置Session存储到关系数据库(MySQL为例):

配置jetty.xml:

打开Jetty目录下的etc/jetty.xml,在Configure元素内部加入XML片段:

<Set name="sessionIdManager">
	<New id="jdbcidmgr" class="org.eclipse.jetty.server.session.JDBCSessionIdManager">
		<Arg>
			<Ref id="Server" />
		</Arg>
		<Set name="workerName">fred</Set>
		<Call name="setDriverInfo">
			<Arg>com.mysql.jdbc.Driver</Arg>
			<Arg>jdbc:mysql://192.168.20.1:3306/jetty_session?user=root&amp;password=123</Arg>
		</Call>
		<Set name="scavengeInterval">60</Set>
	</New>
</Set>
<Call name="setAttribute">
	<Arg>jdbcIdMgr</Arg>
	<Arg>
		<Ref id="jdbcidmgr" />
	</Arg>
</Call>
修改上面XML片段中的数据库连接的URL,如果用其他关系数据库,还要修改数据库驱动。要注意在XML中&符号要转义成&amp;。

配置context xml:

在Jetty的webapps目录下,新建一个XML文件,例如test.xml,这个XML用于配置一个web应用:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE Configure PUBLIC "-//Jetty//Configure//EN" "http://www.eclipse.org/jetty/configure_9_0.dtd">

<Configure class="org.eclipse.jetty.webapp.WebAppContext">
	<Set name="contextPath">/test</Set>
	<Set name="war">D:\test.war</Set>

	<Ref name="Server" id="Server">
		<Call id="jdbcIdMgr" name="getAttribute">
			<Arg>jdbcIdM
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值