消息队列已经几乎成为大中型高吞吐应用的标配,继续根据我们一贯的节约代码的风格,为了复用的目标,抽象出消息队列平台,进行消息队列管理。

环境准备

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

https://www.rabbitmq.com/dotnet.html

PowerDotNet平台化软件架构设计与实现系列(09):消息平台的更多相关文章

  1. PowerDotNet平台化软件架构设计与实现系列(03):系统应用平台

    为了复用和解耦,快速开发更多的系统和应用,我们对自己经常说的"系统"和"应用"进行更高级的提取和抽象. 十多年前入行,辗转至今,写过很多很多应用,个人喜欢分门别 ...

  2. PowerDotNet平台化软件架构设计与实现系列(01):基础数据平台

    本系列我将主要通过图片和少许文字讲解通过个人自研的PowerDotNet进行快速开发平台化软件产品. PowerDotNet不仅仅是包含像Newtonsoft.Json.Dapper.Quartz.R ...

  3. PowerDotNet平台化软件架构设计与实现系列(02):数据库管理平台

    为了DB复用和简化管理,我们对常见应用依赖的DB模块进行更高级的提取和抽象. 虽然一些ORM可以简化DB开发,但是我们还是需要进行改进和优化,否则应用越多,后期管理运维越混乱. 根据常见开发需要,数据 ...

  4. PowerDotNet平台化软件架构设计与实现系列(05):ETCD分布式键值存储平台

    ETCD目前在PowerDotNet已经被用于注册中心和配置管理(常见的配置中心在PowerDotNet中仅仅是一个小小的模块而已)中,作为基础设施的重要组成部分,ETCD的重要性不言而喻. 本文简单 ...

  5. PowerDotNet平台化软件架构设计与实现系列(13):应用监控平台

    本文再写一篇和具体业务逻辑几乎无关的公共服务应用监控平台.PowerDotNet自研的应用监控平台系统,是服务治理的重要拼图,和服务治理平台配合使用效果更好. 监控开源产品非常丰富,站在巨人的肩膀上, ...

  6. PowerDotNet平台化软件架构设计与实现系列(11):日志平台

    所有后端应用几乎都会记录日志,日志系统可以统一抽象出来提供服务. 最近被Log4j2的安全漏洞刷屏了,作为开发人员的我只能咩哈哈几次表示日志处理太难了,只有折腾过的人才知道这里面的艰辛啊. 在实现Po ...

  7. PowerDotNet平台化软件架构设计与实现系列(12):HCRM人员管理平台

    技术服务于业务,良好的技术设计和实现能够大幅提升业务质量和效率. PowerDotNet已经形成了自己的开发风格,很多项目已被应用于生产环境,可行性可用性可靠性都得到了生产环境验证. 编程是非常讲究动 ...

  8. PowerDotNet平台化软件架构设计与实现系列(06):定时任务调度平台

    定时任务是后端系统开发中少不了的一个基本必备技能. 传统的实现定时任务的方式有很多种,比如直接使用操作系统的Timer和TaskSchedule,或者基于Quartz.HangFire.xxl-job ...

  9. PowerDotNet平台化软件架构设计与实现系列(07):数据同步平台

    上文介绍定时任务调度平台的时候提到,定时任务调度平台的类模式一般用于处理耗时较长的任务.但是根据经验,有些耗时较长的任务,可以通过简化业务逻辑.分页.批量多次处理,改造为耗时较小的适合使用RESTfu ...

随机推荐

  1. 洛谷 P7450 - [THUSCH2017] 巧克力(斯坦纳树+随机化)

    洛谷题面传送门 9.13 补之前 8.23 做的题,不愧是鸽子 tzc( 首先我们先来探讨一下如果 \(c_{i,j}\le k\) 怎么做,先考虑第一问.显然一个连通块符合条件当且仅当它能够包含所有 ...

  2. admixture 群体结构分析

    tructure是与PCA.进化树相似的方法,就是利用分子标记的基因型信息对一组样本进行分类,分子标记可以是SNP.indel.SSR.相比于PCA,进化树,群体结构分析可明确各个群之间是否存在交流及 ...

  3. [linux] mv: cannot move $ to $: Directory not empty

    最近测试某流程时,跑的过程报错了,于是检查脚本修改后重新测试.脚本是改过来了,但在shell中运行某步时碰到了如题报错! $ mv MP_genus_network_files/ tax_networ ...

  4. Nginx 动态增加扩展

    Nginx 动态增加扩展 1. 先查看目前nginx已加载模块 /home/nginx-1.18.0 # nginx -V nginx version: nginx/1.18.0 built by g ...

  5. perl 子函数传入多个数组

    perl中的引用和C中的指针一样,用"\"标识,引用后可使用符号"->"取值.解引用则在对应的数据类型前加$,@ 或%. 这里这里用两数组求和做示例,引用 ...

  6. spl_autoload_register的作用

    spl_autoload_register的作用 当php实例化一个类的时候,这个类如果在另外的文件,那么不用include或require的时候就会报错,为了解决这个问题,可以用spl_autolo ...

  7. 关于蓝牙Mesh您必须知道的七件事

    蓝牙技术联盟于7月19日正式宣布,蓝牙(Bluetooth)技术开始全面支持Mesh网状网络.全新的Mesh功能提供设备间多对多传输,并特别提高构建大范围网络覆盖的通信能力,适用于楼宇自动化.无线传感 ...

  8. DOM给表格添加新一行和删除整个行的内容

    DOM用appendChild()给表格添加新一行时,要注意,在HTML中没特别设置<thead>,<tbody>时,会自动添加上,所以要选择表格第一个元素在添加tr. // ...

  9. acclaim

    欲学acclaim,先学claim.即使学会claim,未必记住acclaim. [LDOCE] claim的词源是cry out, shoutverb:1. state that sth is tr ...

  10. [JAVA]动态代理与AOP的千丝万缕

    动态代理与AOP的联系 别的不说,直接上图 首先是AOP切面编程 什么是切面?(自己心里想想就ok)所以所谓的切面编程,你也就懂得大体了,只是这个被切的是个程序而已 那么AOP与动态代理有什么关系呢? ...