一我的能够属于多个项目,一个项目能够有多我的加入,通知的时候,能够通知项目内的全部人,也能够通知部分人或者某个责任人。前端
同一我的不容许登陆两次(不一样浏览器或者不一样电脑登),后面登陆的会将前面登陆的人挤下线。git
能够私聊、也能够建立群聊、上线通知(多个链接的状况)github
用户在界面上选择了多个文件,而后选择批量打包下载,后端后台线程进行压缩、压缩完成后经过signalr通知该用户(的某个链接,好比当前用户开了多个tab页,应该只能推送给操做的那个tab页)redis
名词解释: 业务系统:具体业务功能的系统 推送系统:实际的Signalr系统,跟业务系统分开部署
业务系统调用推送系统的时候传递参数包括,组、用户、推送数据对象,好比以下代码后端
var send = new Send() { // 推送的组,多个用,隔开 GroupId = GroupId, // 关联的UserId 多个用,隔开 UserIds= UserIds, // 是否排除用户 ExcludeUsers=ExcludeUsers, // 实际推送的对象 NotifyObj = new NotifyObj() { Data = Data, NotifyType = NotifyType, OpType= OpType }, };
有GroupIdapi
无GroupId浏览器
一个用户用多个链接、以Set形式存redis中服务器
以Redis中的Hash格式存储,以Group为Key,以链接Id为Name,以UserId为值,一个用户在组中可能多个链接(开多个浏览器tab页),这样设计的好处是能够知足如下的几种状况架构
从redis中直接根据该用户的UserId查询该用户的全部链接,而后经过链接推送便可性能
从redis中根据组名查询出全部的链接Id,经过链接直接推送
这个时候不能根据人查链接Id,须要先根据组获得组中的人、链接Id,而后只给组中这些人对应的链接推送
在redis中存储一份用户与链接的关系;若是有组的状况,同时以Hash形式存储组、链接Id、用户Id
在redis中该用户对应的链接中增长新的链接Id;若是有组的状况,同时以Hash形式存储组、链接Id、用户Id(由于是一链接Id为name的,然而链接Id是不重复的,因此是能够存着同一个组、同一个用户不一样链接这种状况的)
在redis中找到该用户,从redis中删除改用户的找个链接Id,组的状况一样处理
好比:用户点击打包下载,服务器端后台线程进行打包、压缩,完成后推送给指定的链接Id,前端界面再进行处理下载
至此,业务分析完毕,更多内容请经过快速导航查看下一篇
标题 | 内容 |
---|---|
索引 | .net core 3.0 Signalr - 实现一个业务推送系统 |
上一篇 | .net core 3.0 Signalr - 05 使用jwt将用户跟signalr关联 |
下一篇 | .net core 3.0 Signalr - 07 业务实现-服务端 自定义管理组、用户、链接 |
源码地址 | 源码 |
官方文档 | 官方文档 |