我目前正在建立一个Web应用程序,并且想使用Redis来存储会话。登录时,会话将使用相应的用户ID插入到Redis中,并且到期时间设置为15分钟。我现在想对会话实施反向查找(获取具有特定用户ID的会话)。这里的问题是,由于我无法搜索Redis键空间,因此该如何实现。一种方法是为每个userId设置一个redis,其中包含所有会话ID。但是由于Redis不允许集合中的某个项目过期,并且会话设置为过期,因此集合中将存在大量不存在的会话ID。
从密钥到期时从集合中删除ID的最佳方法是什么?或者,是否有更好的方法来完成我想要的操作(反向查找)?
在Redis(2.6)的当前版本分支上,项目过期时无法收到通知。下一版本可能会更改。
同时,为了满足您的要求,您需要手动实施过期通知支持。所以你有了:
session:<sessionid> -> a hash storing your session data - one of the field is <userid>
user:<userid> -> a set of <sessionid>
会话过期时,您需要从用户集中删除sessionid。因此,您可以维护得分为时间戳的其他排序集。
当您为用户100创建会话10时:
MULTI
HMSET session:10 userid:100 ... other session data ...
SADD user:100 10
ZADD to_be_expired <current timestamp + session timeout> 10
EXEC
然后,您需要构建一个守护程序,该守护程序将轮询zset以确定会话即将过期(ZRANGEBYSCORE)。对于每个过期的会话,它必须维护数据结构:
主要困难在于确保守护程序轮询和处理项目时不存在争用条件。请参阅我对这个问题的回答,以了解如何实施
我在global.asax中尝试了以下代码,但不起作用,并导致Application_Error(“响应在此上下文中不可用。”)。
问题内容: 我们有一个内部ASP.NET MVC应用程序,需要登录。登录效果很好,并且可以完成预期的工作。会话的有效期为15分钟。在该页面上坐了一段时间后,用户丢失了会话。如果他们尝试刷新当前页面或浏览到另一个页面,他们将获得登录页面。我们会将他们的请求存储起来,以便他们登录后可以继续进入他们请求的页面。这很好。 但是,我的问题是,在某些页面上有AJAX调用。例如,他们可以填写表格的一部分,徘徊并
TLDR:我如何使用从后台发送的数据初始化我的对话,并在与用户的整个对话中使用这些信息? 使用Microsoft botbuilder,提供了一种“反向通道”机制,我可以通过它向bot发送数据,也可以从bot发送数据。 与此答案类似,我正在使用backchannel方法向bot发送conversationStarted事件,以便按照您的预期启动对话。 收到事件后,我启动一个对话框,向用户发送主动消
我试图使用Spring Cloud的Zuul、Eureka和我自己的服务实现微服务架构。我有多个具有UI和服务的服务,每个服务都可以使用x509安全性对用户进行身份验证。现在我想把祖尔放在那些服务机构的前面。由于Zuul无法将客户端证书转发到后端,我认为下一个最好的方法是在Zuul的前门对用户进行身份验证,然后使用Spring会话在后端服务中复制他们的身份验证状态。我遵循了Dave Syer的教程
问题内容: 我将会话参数存储在Struts2会话映射中,该会话映射是使用SessionAware接口在操作中获得的。我的应用程序位于/ MyApp路径中。 在具有反向代理重定向的Apache服务器上设置struts2应用程序之后,该重定向使URL http://www.appdomain.com/ 指向本地 主机 上的本地tomcat :8080 / MyApp ,Struts2会话处理不再起作用
我正在使用Spring Boot、Spring Security性和spring会话(redis)构建spring REST web应用程序。我正在使用SpringCloud和zuul代理按照网关模式构建一个云应用程序。在这个模式中,我使用spring会话来管理redis中的HttpSession,并使用它来授权我的资源服务器上的请求。当执行更改会话权限的操作时,我希望更新该对象,以便用户不必注销