redis sortedset<loginId, upTime> 记录在线人数
登录: zadd
退出: zrem
已登录请求: zadd(update) 性能考虑可以N秒更新一次,上次更新时间可以用session cookie jwt 之类保持
N秒周期移除掉线的人: zremrangebyscore key 0 datetime.now - x minute(多久没请求则视为掉线)
N秒或者实时刷新在线人数: zcard直接拿, zcount now-x minute now 实时统计在线人数。
如果你是单机, 直接一个memorycahce 就完事了。。。
多久没请求则视为掉线,这个规则能改成自动监听cookies或者session失效吗?
@尾随前行: 你的session有固定的过期时间呀... 比如30分钟.
这个要看业务,看要怎么统计
就是在用户登陆、退出、登陆失效统计在线人数
用户登陆、退出这个属于主动操作,系统能记录到,现在不知道怎么解决登陆失效这个统计。在代码中调用了HttpContext.SignInAsync,那我该怎么知道 Cookie或者 Session的过期时间呢
这个要怎么统计不是由你的业务决定的吗? 哪来的插件
是的,是由业务决定的。 系统除了登陆和退出这两个操作能去统计在线人数,还有一个登陆状态失效也需要统计在线人数,这里不知道该怎么去统计 。。
把登录用户的在状态记录在redis
比如 离线=0 在线=1