我们正在尝试为跨服务器的零售商提供一种非粘性会话解决方案。 使用的服务器是WebLogic 12.2.1.3和TomcatEE 7.0.5。我们能够看到会话在服务器之间持续存在。
httpServletRequest.getSession()
有时试图从容器而不是GemFire检索会话。
我们在客户端Cookie和服务器日志中看到的会话ID也不同于GemFire内部显示的会话ID。这是预期的吗?
编辑: 在GemFire中创建的会话ID在客户端浏览器上使用base64编码。这将回答上述问题。
答案 0 :(得分:0)
请确保已在同时跨WebLogic和TomcatEE部署的所有(Spring Boot)应用程序实例中“启用”了 Pivotal GemFire的Spring Session 。这很简单,如下所示:
@SpringBootApplication
@EnableGemFireHttpSession
class MySpringBootWebApplication {
public static void main(String[] args) {
SpringApplication.run(MySpringBootApplication.class, args);
}
...
}
@EnableGemFireHttpSession
是关键。还要确保部署在每个WebLogic和TomcatEE中的应用程序实例在后端Pivotal GemFire群集中共享同一区域,并假设在WebLogic和TomcatEE中都存在一个为应用程序提供服务的单一GemFire群集。
例如,如果您明确设置了“区域”,则使用:
@EnableGemFireHttpSession(regionName = "MySessionRegion")
确保所有应用程序实例使用相同的区域名称(即“ MySessionRegion”)。另外,从SSDG 2.0.5.RELEASE
开始,可以使用Spring Boot的application.properties
文件中的属性来配置区域名称:
spring.session.data.gemfire.session.region.name=MySessionRegion
此外,请确保所有应用程序都配置为与同一个GemFire集群通信。这取决于Spring Session Region用于与GemFire集群进行对话的Pool
。池名称可以使用注释进行配置,如下所示:
@EnableGemFireHttpSession(..., poolName = "SessionPool")
然后,您必须为所有应用程序实例配置“池”以连接到同一个GemFire集群,最好使用Locators,就像这样:
@配置 类MyGemFireConfiguration {
@Bean("SessionPool")
PoolFactoryBean sessionPool() {
PoolFactoryBean sessionPool = new PoolFactoryBean();
sessionPool.setName("SessionPool");
sessionPool.setLocators(Arrays.asList(new ConnectionEndpoint("host1", port1),
new ConnectionEndpoint("host2", port2),
...,
new ConnectionEndpoint("hostN", portN));
return sessionPool;
}
...
}
或者,您可以配置“ DEFAULT” GemFire池,假设已配置的存储会话状态的客户端PROXY Region使用“ DEFAULT”池,当没有显式配置/命名池时,它将使用“ DEFAULT”池。对于example。
最后要注意的是,如果您使用的是GemFire WAN拓扑,其中有多个站点,每个站点都服务于由应用程序服务器隔离的特定应用程序集合(例如,WebLogic与TomcatEE)。然后,您必须确保已配置适当的GemFire WAN,以跨多个GemFire群集进行协调。这超出了此答案的范围,因此,我鼓励您查看this。
随时共享您可能会发现的所有示例代码,配置和/或测试。