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 ...
随机推荐
- 监听浏览器tab切换
监听浏览器切屏 为了完成验证用户在切换浏览器tab时进行登录再次认证需求需要监听浏览器切换窗口 if (document.hidden !== undefined) { document.addEve ...
- Kubernetes:Pod 升级、回滚
本篇主要讨论如何实现滚动更新和回滚,任意更换版本并且回滚以前的版本(版本更新),而下一章会讨论到 Pod 缩放,根据机器资源自动拓展和收缩应用(自动扩容实例). 本文为作者的 Kubernetes 系 ...
- R包 tidyverse 分列
代码: 1 library(tidyverse) 2 separate(data = df,col=chr_pos,into=c("chr","pos"),se ...
- linux 两服务器之间的文件传输scp
Linux scp 命令用于 Linux 之间复制文件和目录. scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令. scp 是加 ...
- 61. Binary Tree Inorder Traversal
Binary Tree Inorder Traversal My Submissions QuestionEditorial Solution Total Accepted: 123484 Total ...
- centos yum安装mongodb,php扩展
一,安装mongodb,php扩展 ? 1 [root@localhost ~]# yum install php-pecl-mongo mongodb mongodb-devel mongodb-s ...
- 9 — springboot整合jdbc、druid、druid实现日志监控 — 更新完毕
1.整合jdbc.druid 1).导入依赖 <dependency> <groupId>org.springframework.boot</groupId> &l ...
- python-3.x-生成器使用
生成器函数代码: 1 def gen(n): 2 i = 1; 3 sum = 0; 4 while i <= n: 5 ''' 6 方法体1 -- sum求和是1到9的和 7 yield su ...
- webpack打包报错 ERROR in ./js/ww.js from UglifyJs Unexpected token keyword «function», expected punc «,» [src/page/ww/view/xx/xx.vue:119,0][./js/ww.js:55218,17]
找了好多解决办法 你可以试着将babel-loader的exclude注释掉,然后看能否打包成功.如果可以,那就是这个问题.你只需要在vue.config.js中配置transpileDependen ...
- 从面试官的角度,聊聊java面试流程
在这篇回答里,就讲以我常规的面试流程为例,说下java方面大致会问什么问题,以及如何确认候选人达到招聘要求. 先说面试前准备,可能有些面试官是拿到简历直接问,而且是在候选人自我介绍时再草草浏览简历,但 ...