PowerDotNet平台化软件架构设计与实现系列(09):消息平台
消息队列已经几乎成为大中型高吞吐应用的标配,继续根据我们一贯的节约代码的风格,为了复用的目标,抽象出消息队列平台,进行消息队列管理。
环境准备
1、(必须).Net Framework4.5+
2、(必须)关系型数据库MySQL或SqlServer或PostgreSQL或MariaDB四选一
3、(必须)PowerDotNet数据库管理平台,主要使用DBKey功能
4、(必须)PowerDotNet配置中心Power.ConfigCenter
5、(必须)PowerDotNet注册中心Power.RegistryCenter
6、(必须)PowerDotNet缓存平台Power.Cache
7、(必须)PowerDotNet基础数据平台Power.BaseData
8、(必须)PowerDotNet人员管理平台Power.HCRM,后续文章详细介绍
9、(必须)RabbitMQ
一、消息队列
PowerDotNet默认支持的消息队列是RabbitMQ和MSMQ(本文重点讲讲RabbitMQ),并可以继续抽象,预留扩展接口,后续可以支持更多种消息队列,比如RocketMQ、ZeroMQ、Kafka等。
1、消息队列服务器

PowerDotNet重点支持RabbitMQ,精心开发了RabbitMQ消息队列管理后台,支持常用统计和连接、通道、交换机、队列、RoutingKey绑定和用户相关的常用操作。

消息队列默认就支持集群高可用部署,推荐使用镜像模式。

公共队列工具可以方便大家快速排查定位问题。
3、消息队列分组
和缓存非常类似,对于大中型企业来说,消息队列也经常需要按照业务团队进行分组管理。
PowerDotNet完美支持按照系统和应用进行MQKey绑定,做到按组管理。
先定义MQKey,一个MQKey等同于一个消息队列分组:

绑定MQKey到具体应用:

和缓存平台一样,只用使用公共消息队列组件Power.MQ,直接在管理后台点点按钮,配置中心配置一下应用所使用的MQKey,应用就自动拥有了使用消息队列的能力,开发应用不要太容易,咩哈哈。

使用消息平台,对开发人员,很容易使用和维护消息队列,谁用谁知道。
二、消息管理
绝大多数公司,几乎都会用到的主要几个消息沟通工具,比如邮件、短信、微信、钉钉等消息。
消息的发送默认都是通过消息队列,当然可以通过配置中心开关配置为直接发送或写库异步发送。这里你可以认为消息是对消息队列的最佳实践,是不是比较拗口?咩哈哈。
这里的“消息”和消息队列平台完全没有关系。仅仅只是我的个人开发经验,把邮件、短信、微信、钉钉等可复用的消息管理也归属到消息平台而已。
1、消息配置

配置的内容还挺多:

支持邮件、短信和微信的动态配置。钉钉则比较特殊,可以通过配置中心配置。
2、消息模板
有过短消息或者推送系统的开发人员就知道消息模板的重要性了,可以省去很多很多代码。

3、消息管理

对于某些敏感消息,可能需要加密或脱敏处理,或者干脆不存储敏感内容,PowerDotNet的消息管理有配置参数支持这一种特殊逻辑,点点按钮即可搞定。
发送的消息,可能成功,可能失败,可以通过消息管理进行特殊业务逻辑,如错误消息重试、定时异步发送等,对于这些主要功能,PowerDotNet都做到了,强大的消息平台让你的应用开发如虎添翼。
参考:
https://www.rabbitmq.com/dotnet.html
PowerDotNet平台化软件架构设计与实现系列(09):消息平台的更多相关文章
- PowerDotNet平台化软件架构设计与实现系列(03):系统应用平台
为了复用和解耦,快速开发更多的系统和应用,我们对自己经常说的"系统"和"应用"进行更高级的提取和抽象. 十多年前入行,辗转至今,写过很多很多应用,个人喜欢分门别 ...
- PowerDotNet平台化软件架构设计与实现系列(01):基础数据平台
本系列我将主要通过图片和少许文字讲解通过个人自研的PowerDotNet进行快速开发平台化软件产品. PowerDotNet不仅仅是包含像Newtonsoft.Json.Dapper.Quartz.R ...
- PowerDotNet平台化软件架构设计与实现系列(02):数据库管理平台
为了DB复用和简化管理,我们对常见应用依赖的DB模块进行更高级的提取和抽象. 虽然一些ORM可以简化DB开发,但是我们还是需要进行改进和优化,否则应用越多,后期管理运维越混乱. 根据常见开发需要,数据 ...
- PowerDotNet平台化软件架构设计与实现系列(05):ETCD分布式键值存储平台
ETCD目前在PowerDotNet已经被用于注册中心和配置管理(常见的配置中心在PowerDotNet中仅仅是一个小小的模块而已)中,作为基础设施的重要组成部分,ETCD的重要性不言而喻. 本文简单 ...
- PowerDotNet平台化软件架构设计与实现系列(13):应用监控平台
本文再写一篇和具体业务逻辑几乎无关的公共服务应用监控平台.PowerDotNet自研的应用监控平台系统,是服务治理的重要拼图,和服务治理平台配合使用效果更好. 监控开源产品非常丰富,站在巨人的肩膀上, ...
- PowerDotNet平台化软件架构设计与实现系列(11):日志平台
所有后端应用几乎都会记录日志,日志系统可以统一抽象出来提供服务. 最近被Log4j2的安全漏洞刷屏了,作为开发人员的我只能咩哈哈几次表示日志处理太难了,只有折腾过的人才知道这里面的艰辛啊. 在实现Po ...
- PowerDotNet平台化软件架构设计与实现系列(12):HCRM人员管理平台
技术服务于业务,良好的技术设计和实现能够大幅提升业务质量和效率. PowerDotNet已经形成了自己的开发风格,很多项目已被应用于生产环境,可行性可用性可靠性都得到了生产环境验证. 编程是非常讲究动 ...
- PowerDotNet平台化软件架构设计与实现系列(06):定时任务调度平台
定时任务是后端系统开发中少不了的一个基本必备技能. 传统的实现定时任务的方式有很多种,比如直接使用操作系统的Timer和TaskSchedule,或者基于Quartz.HangFire.xxl-job ...
- PowerDotNet平台化软件架构设计与实现系列(07):数据同步平台
上文介绍定时任务调度平台的时候提到,定时任务调度平台的类模式一般用于处理耗时较长的任务.但是根据经验,有些耗时较长的任务,可以通过简化业务逻辑.分页.批量多次处理,改造为耗时较小的适合使用RESTfu ...
随机推荐
- python-面向过程、面向对象、类
目录 python-面向过程.面向对象.类 面向过程编程 面向对象 类和对象 二者区别 定义格式: 定义类发生的事情 定义类的标准格式 属性的查找顺序 python-面向过程.面向对象.类 面向过程编 ...
- MEGAN4,MEGAN5和MEGAN6的Linux安装和使用
目录 MEGAN 4 MEGAN 5 MEGAN 6 MEGAN(Metagenome Analyzer)是宏基因组学进行物种和功能研究的常用软件,实际上现在的Diamond+MEGAN6已经是一套比 ...
- python 新闻管理系统——启示
mysql取整函数: mysql函数ceil.floor.round mysql 取整 1.ceil() / ceiling() 向上取整 ex: ceil(1.2) = 2 2.floor() 向下 ...
- cpu的性能测试
#!/bin/bash #user%加上sys%是性能的评判标准 User_sys_a=`sar -u 1 3 |tail -1 |awk '{print $3"+"$5}'|bc ...
- Linux—linux 查看一个文件有多少M
ls -l --block-size=M #就把目录下的所有文件按M单位呈现
- 33、搜索旋转排序数组 | 算法(leetode,附思维导图 + 全部解法)300题
零 标题:算法(leetode,附思维导图 + 全部解法)300题之(33)搜索旋转排序数组 一 题目描述! 题目描述 二 解法总览(思维导图) 三 全部解法 1 方案1 1)代码: // 方案1 & ...
- 【NetCore】RabbitMQ 封装
RabbitMQ 封装 代码 https://gitee.com/wosperry/wosperry-rabbit-mqtest/tree/master 参考Abp事件总线的用法,对拷贝的Demo进行 ...
- 线性表A,B顺序存储合并
线性表A,B顺序存储合并 有两张非递增有序的线性表A,B,采用顺序存储结构,两张表合并用c表存,要求C为非递减有序的,然后删除C表中值相同的多余元素.元素类型为整型 输入格式: 第一行输入输入表A的各 ...
- day11 函数
day11 函数 一.函数基础 """ 1 什么是函数 函数是盛放代码的容器:把实现某一功能的代码放到一个函数内就制造一个工具 2 为何要用函数 没有用函数之前程序的问题 ...
- 重磅丨腾讯云开源业界首个 etcd 一站式治理平台 Kstone
Kstone 开源 在 CNCF 云原生基金会举办的2021年12月9日 KubeCon China大会上,腾讯云容器 TKE 团队发布了 Kstone etcd 治理平台开源项目. Kstone ...