## 业务需求
1. 人-项目关系
一个人可以属于多个项目,一个项目可以有多个人加入,通知的时候,可以通知项目内的所有人,也可以通知部分人或者某个责任人。
2. 登录互斥
同一个人不允许登录两次(不同浏览器或者不同电脑登),后面登录的会将前面登录的人挤下线。
3. 聊天
可以私聊、也可以创建群聊、上线通知(多个连接的情况)
4. 文件下载
用户在界面上选择了多个文件,然后选择批量打包下载,后端后台线程进行压缩、压缩完成后通过signalr通知该用户(的某个连接,比如当前用户开了多个tab页,应该只能推送给操作的那个tab页)

## 功能设计
> 名词解释: 业务系统:具体业务功能的系统 推送系统:实际的Signalr系统,跟业务系统分开部署
1. 将推送单独成一个子系统;支持单独部署,可一台服务器也可以多台,通过redis作为底板来分发到服务器
2. 推送子系统端自定义管理用户、连接、组,业务系统调用的时候
3. 推送系统开发一个api,给业务系统直接调用(当然这不是最佳选择,可以通过消息队列,支持重试、优先级等,性能会比http形式好很多)
业务系统调用推送系统的时候传递参数包括,组、用户、推送数据对象,比如如下代码
``` C#
var send = new Send()
{
// 推送的组,多个用,隔开
GroupId = GroupId,
// 关联的UserId 多个用,隔开
UserIds= UserIds,
// 是否排除用户
ExcludeUsers=ExcludeUsers,
// 实际推送的对象
NotifyObj = new NotifyObj()
{
Data = Data,
NotifyType = NotifyType,
OpType= OpType
},
};
```
* 有GroupId
* ExcludeUsers=true
推送给指定的组中所有用户(排除掉UserIds部分)

* ExcludeUsers=false
推送给组中指定(UserIds中指定的)的这些用户

* 无GroupId
* ExcludeUsers=true
推送给当前所有连接(排除掉UserIds部分的用户)

* ExcludeUsers=false
推送给指定用户(UserIds中指定的用户)

## 架构设计
1. 组、用户、连接的关系
- 用户:[连接Id]
一个用户用多个连接、以Set形式存redis中
- 组:[连接Id:用户Id]
以Redis中的Hash格式存储,以Group为Key,以连接Id为Name,以UserId为值,一个用户在组中可能多个连接(开多个浏览器tab页),这样设计的好处是可以满足以下的几种情况
* 给某个人推送
从redis中直接根据该用户的UserId查询该用户的所有连接,然后通过连接推送即可
* 给某个组推送
从redis中根据组名查询出所有的连接Id,通过连接直接推送
* 给某个组中的某些人推
这个时候不能根据人查连接Id,需要先根据组得到组中的人、连接Id,然后只给组中这些人对应的连接推送
* 用户上线的时候
在redis中存储一份用户与连接的关系;如果有组的情况,同时以Hash形式存储组、连接Id、用户Id
* 用户再开一个浏览器tab页
在redis中该用户对应的连接中增加新的连接Id;如果有组的情况,同时以Hash形式存储组、连接Id、用户Id(因为是一连接Id为name的,然而连接Id是不重复的,所以是可以存着同一个组、同一个用户不同连接这种情况的)
* 用户退出页面
在redis中找到该用户,从redis中删除改用户的找个连接Id,组的情况同样处理
* 给某个用户的某个连接Id推送
比如:用户点击打包下载,服务器端后台线程进行打包、压缩,完成后推送给指定的连接Id,前端界面再进行处理下载

至此,业务分析完毕,更多内容请通过快速导航查看下一篇

## 快速导航

| 标题 | 内容
| :--- | :---
| 索引 | [.net core 3.0 Signalr - 实现一个业务推送系统](/2019/09/20/dotnetcore/signalr/00-introduct/)
| 上一篇 | [.net core 3.0 Signalr - 05 使用jwt将用户跟signalr关联](https://blogs.xxgtalk.cn/2019/10/02/dotnetcore/signalr/05-jwt/)
| 下一篇 | [.net core 3.0 Signalr - 07 业务实现-服务端 自定义管理组、用户、连接](https://blogs.xxgtalk.cn/2019/10/04/dotnetcore/signalr/07-self-manager/)
| 源码地址 | [源码](https://github.com/xiexingen/CTS.Signalr)
| 官方文档 | [官方文档](https://docs.microsoft.com/zh-CN/aspnet/core/?view=aspnetcore-3.0)

![二维码](https://img2018.cnblogs.com/blog/394514/201910/394514-20191005214952856-108155381.gif)

.net core 3.0 Signalr - 06 业务实现-业务分析的更多相关文章

  1. .net core 3.0 Signalr - 实现一个业务推送系统

    ## 介绍 ASP.NET Core SignalR 是一个开源代码库,它简化了向应用添加实时 Web 功能的过程. 实时 Web 功能使服务器端代码能够即时将内容推送到客户端. SignalR 的适 ...

  2. .net core 3.0 Signalr - 07 业务实现-服务端 自定义管理组、用户、连接

    Hub的管理 重写OnConnectedAsync 从连接信息中获取UserId.Groups,ConnectId,并实现这三者的关系,存放于redis中 代码请查看 using CTS.Signal ...

  3. .net core 3.0 Signalr - 05 使用jwt将用户跟signalr关联

    Signalr是以Group.Connect为核心来进行推送,比如,给某个组.某个连接来推送,但实际场景中,核心应该是某个组.某个人:然而一个人可以对应多个连接(浏览器多个tab页):本节就来介绍下自 ...

  4. .net core 3.0 Signalr - 08 业务实现-客户端demo

    由于signalr作为一个单独的推送系统,跟业务系统是分离开的,所以此处模拟一个业务系统,新建一个.net core app项目 ## 模拟实现一个登录功能 我们的登录很简单,当进入系统,如果检测到用 ...

  5. .net core 3.0 Signalr - 01 基础篇

    因为将signalr作为单独的站点,此处需要建立两个项目,一个专门用于signalr作为推送项目,一个客户端(实际的业务项目) ## 基础知识速览 ### Clients对象属性 | 属性 | 描述 ...

  6. .net core 3.0 Signalr - 02 使用强类型的Hub

    ## 强类型的优缺点 - 优点 强类型的Hub可以避免魔法函数名,相比弱类型更容易维护和发现问题,直接上代码 - 缺点 特么的得多些好几行代码 ## 代码 ### 接口定义 ``` C# /// // ...

  7. .net core 3.0 Signalr - 03 使用MessagePack压缩传输内容

    ## MessagePack基础介绍 Signalr默认使用的是json形式传递数据,但是signalr提供了灵活的扩展,支持MessagePack形式序列化数据,以增加性能降低网络传输的效果,极大的 ...

  8. .net core 3.0 Signalr - 04 使用Redis做底板来支持横向扩展

    在实际的系统中,可能需要多台机器部署;然而,Signalr的连接信息是跟站点走的,举个例子 推送系统部署了A.B两个服务器,张三访问A服务器,李四访问B服务器,当张三通过A服务器向李四推送的时候,A服 ...

  9. .net core 3.0 Signalr - 09 待改进&交流

    ## 个人心得 写博客真的比写代码累,膜拜那些坚持写博客的大佬! 有时候零散的片段比较多,没写之前感觉有千千万万要写的东西,实际写的时候发现, 好像这个没啥说的,然后就帖了个图,或者一笔带过了 ## ...

随机推荐

  1. 撤销git add添加的文件

    git add 添加了多余文件 git add .  表示当前目录所有文件,不小心就会提交其他文件 git add 如果添加了错误的文件的话 撤销操作 git status 先看一下add 中的文件  ...

  2. CentOS7安装mysql8.0.12

    一.配置yum源 下载mysql源安装包 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo/yum/ 复制下载链接:https://d ...

  3. StackOverflow 周报 - 与高关注的问题过过招(Java)

    本篇文章是 Stack Overflow 周报的第二周,共收集了 4 道高关注的问题和对应的高赞回答.公众号「渡码」为日更,欢迎关注. DAY1.  serialVersionUID 的重要性 关注: ...

  4. codeforce375div2-D. Lakes in Berland 搜索

    Lakes in Berland 题意与解释:这道题就是求图中被围起来的点群,问最少去掉几个点,可以使得孤立的点群数目为K; 因为自己写的代码又长又had bugs. 我自己写的bfs,想着是先染色, ...

  5. 模板汇总——treap

    1. 旋转treap. 思想:一颗权值BST + 一颗 随机数 最小堆. BZOJ - 3224 代码: #include<bits/stdc++.h> using namespace s ...

  6. CodeForces 601B Lipshitz Sequence

    Lipshitz Sequence 题解: 可以通过观察得到,对于任意一个区间来说, 只有相邻的2个点的差值才会是区间的最大值. 具体观察方法,可以用数学分析, 我是通过画图得到的. 那么基于上面的观 ...

  7. POJ 2491 Scavenger Hunt map

    Scavenger Hunt Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 2848   Accepted: 1553 De ...

  8. codeforces 820 D. Mister B and PR Shifts(思维)

    题目链接:http://codeforces.com/contest/820/problem/D 题意:求.有一种操作 k = 0: shift p1, p2, ... pn, k = 1: shif ...

  9. HDU 4565 So Easy! 广义斐波拉数 数论 (a+sqrt(b))^n%mod 模板

    So Easy! Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  10. Atcoder E - RGB Sequence(dp)

    题目链接:http://arc074.contest.atcoder.jp/tasks/arc074_c 题意:一共有3种颜色,红色,绿色,蓝色.给出m个要求l,r,x表示在区间[l,r]内要有x种不 ...