产品设计——应用架构

news2024/10/26 1:32:36

   我的理解应用架构是业务架构的落地,微服务架构下平台的应用架构设计,实质是根据业务来明确应用微服务的边界。因此业务不同,应用架构图也不同。但是基本框架应该相差不大。

        其划分原则莫过于高内聚、低耦合。这个跟接口设计是一致的。我们总是想降低业务之间的关联程度。简单的道理,就是发布一个微服务,尽量不要少影响业务。业务耦合性很强,维护起来成本大,发布上线对用户使用也是糟心。

        其分层原则则是根据水平、垂直维度进行划分。水平和垂直的划分,总的有个标准。水平划分的深度最易理解的是根据面向用户设计架构的远近,垂直的划分总根据用途交易划分,实在无法划分的,至少水平方向是那一层还是可以明确了。有了这样的结构化思维,脑海里面就对平台有个概要认知。

  下面着重讲一下网关、业务服务、能力服务,这三个就是应用架构的主体。无论是业务平台,基本应该都可以这么划分。

网关

        现在基本都是前后端分离的服务,网关的重要性在应用分发和鉴权。针对自身用户使用的云平台和第三方系统对接的用户,采用不同的入口。

        开放接口网关,一般是基于oauth2.0协议,对接是第三方的应用系统,第三方系统访问的授权是基于应用,并不是针对用户,这个跟内部网关是区别的。为什么会有开放接口网关微服务和开放鉴权服务两个呢,因为spring-cloud-starter-oauth2已经讲Oauth2.0封装好了,它自身已经比较完备了,可操作空间不大。而接口鉴权微服务,是用来设计第三方系统是否有该接口的权限,接口的访问频率、访问次数控制,这个对接数据库,有通用化设计也有其个性化设计,因此这个可以单独拿出来作为一个独立的微服务。

业务服务

        业务服务是跟其公司的业务相关,电商平台跟我们岁月会计云是不一样。我们是财税类产品,主要业务是财务、供应链、档案、运营四部分。

        运营的作用是为平台中各子产品提供可配置的权限和套餐组合,另外记录用户的订单信息。

        而财务、供应商、档案这三条子产品线微服务划分,是根据其系统中功能的复杂程度设计。从上午可以看出财务系统比较复杂。

能力服务

        写ppt的时候总喜欢说能力支撑,能力服务层就是给上面业务服务提供支付、扫码登录、即时通讯、统计以及对接第三方系统的能力。

        IM微服务,之所以设计这个微服务是因为前端websocket通讯,总不能对接一个微服务就建立一个地址建立连接,因此设计一个统一的服务,如此websocket通讯就有了极高的扩展性。

        支付微服务,为什么有这个呢?三方支付、四方支付其核心是清算系统,而支付微服务不同的是为各应用服务提供统一的支付渠道调用,当时是仿照ping++设计的。因为微信和支付宝支付接口参数是不一样的,而通联支付等也是不一样的。之所以对接不同的支付渠道,无非是因为税率原因。提供标准的支付接口给到用到支付的应用产品,调SDK即可,开发就变得很简单了。

        微信相关微服务,这个是历史原因,微信的生态是渐进变化,之前只有微信公众号,后来有了微信小程序,再就有了企业微信私域。因此它的研究是伴随微信的发展,于是该服务就独立演进保留了下来。

        统计微服务现在设计的不是很好,后面有时间再改,但是一个小公司总不能非要用clickhouse来统计吧。有时间再研究。

       

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2210586.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL数据库安装手册

MySQL数据库安装手册 MySQL数据库的下载与安装 在上一小节我们已经简单了解了数据库与一些相关概念 没看上一节的同学戳这里 接下来我们首先需要学会如何下载和安装数据库 1 MySQL数据库的版本 目前MySQL官网为我们提供了两个版本,一个是社区版本,…

<<迷雾>> 第11章 全自动加法计算机(4)--带地址译码器的内存模型 示例电路

地址译码器 info::操作说明 书中没有给出具体的实现电路. 这里根据电路特性采用自定义逻辑实现. 关于 “自定义逻辑”, 可参考此链接的说明: https://book.xiaogd.net/usage-of-circuitjs/circuitjs-custom-logic.html 这里本质上就是利用两个 2-4 译码器分别控制读和写. 注: 在…

Linux进程控制(3)(进程程序替换2 -- 微型shell)

目录 补充 一.引入 二.自助微型shell 1:输出一个命令行 2:获取用户命令字符串 3:命令行字符串的分割 4:先试着执行一下命令 5:关键点:需要在执行命令前检查是否为内建命令 其他: 三&…

JSONAJAX

JSON&&AJAX 一、JSON 1.1 json简介 JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。JSON采用完全独立于语言的文本格式,而且很多语言都提供了对 json 的支持(包括 C, C, C#, J…

常用的devops工具集成方法

常用的devops工具集成方法涵盖了软件开发和运维的各个方面,从版本控制到自动化构建、测试、部署和监控。这些工具的有效集成可以帮助团队提高协作效率,减少沟通障碍,实现快速、高质量的软件交付。以下是对这些工具集成方法的具体介绍&#xf…

双核DSP芯片的内存管理

总体框图 总的来说,在这款DSP芯片上,RAM分成了四种不同的类型: 专用RAM: CPU专用的内存,其他主机无法访问。 双核共享RAM: CLA和CPU共享内存,双方都可以对内存地址进行访问 MSGRAM: CLA和CPU之间传递数据的…

【自动驾驶汽车通讯协议】I2C(IIC)总线通讯技术详解

文章目录 0. 前言1. I2C简介2.I2C的工作原理2.1 硬件要求:2.2 半双工通信: 3. 通信时序4. 其他特性4.1 通信速率4.2 抗干扰措施4.3 注意事项 5. 在自动驾驶汽车中的应用5.1 I2C操作模式5.2 I2C的用途 6. 总结 0. 前言 按照国际惯例,首先声明&…

Spring Boot知识管理系统:创新与实践

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统,它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等,非常适…

【含开题报告+文档+PPT+源码】基于人脸识别的课堂考勤系统的设计与实现

开题报告 随着科技的不断发展,人脸识别技术已经逐渐渗透到各个领域,包括教育领域。传统的课堂考勤方式通常依赖于学生签到或教师手动记录,这种方式存在着许多不足之处,例如容易出现人为错误、耗费时间和资源等。为了解决这些问题…

机器学习:强化学习中的探索策略全解析

引言 在机器学习的广阔领域中,强化学习(Reinforcement Learning, RL)无疑是一个充满魅力的子领域。它通过智能体与环境的交互,学习如何在特定的任务中做出最优决策。然而,在这个过程中,探索(ex…

linux 配置ssh免密登录

一、 cd /root/.ssh/ #不存在就创建mkdir /root/.ssh ssh-keygen #连续按4个回车 ll二、将公钥发送到目标服务器下 #公钥上传到目标服务器 ssh-copy-id root192.168.31.142 #回车完也是要输入密码的 #测试一下免密登录: ssh root192.168.31.142 成功

二、后台管理系统布局菜单可拖动

前两天产品提出了一个需求,说后台管理系统的左边菜单的名称字数过多,遮挡了。希望能让客户能够看到全部的名称,给左侧菜单增加一个可拖动的功能,经过我的研究,这个功能最终也做出来了,先看效果,…

IDEA之手动添加作者信息

IDEA不能像eclipse一样,直接使用/**注释快捷键在类上带出作者信息。 解决方案: 手动添加自定义作者注释快捷键 /*** Author: TroubleBoy* Date: $DATE$* Description: TODO*/ 6.编辑日期变量,设置变量DATE的Expression为date() 7.应用Java…

Nacos的相关资料

目录 Nacos的Mysql文件: custom.env文件: 执行的Docker命令: 从 GitHub 官方仓库下载 Nacos:https://github.com/alibaba/nacos Nacos的Mysql文件: -- --------------------------------------------------------…

【工具类】hutool http请求获取S3图片流

博主介绍:✌全网粉丝20W,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…

基于数字信号处理的语音数字识别器

基于数字信号处理的语音数字识别器 系统说明 该系统工作流程图如下 各部分关键参数及简要说明如下。 预处理阶段: 预录制语音为单个数字的语音,从 0 - 9 共 10 组,采样率 16 kHz计算 MFCC 特征中,Mel 滤波器组个数 40&#xff…

Journey Training:o1的一次复现尝试,极长思维链的合成

知乎:啦啦啦啦(已授权)链接:https://zhuanlan.zhihu.com/p/902522340 论文:O1 Replication Journey: A Strategic Progress Report链接:https://github.com/GAIR-NLP/O1-Journey 这篇论文记录了一次o1复现尝…

IBMS集成管理平台——推动建筑业数字化转型

随着城市发展和科技进步,智慧楼宇(IBMS)作为建筑智能化的核心系统,已经成为现代建筑中不可或缺的一部分。通过整合各种智能设备和系统,IBMS提供了对建筑内部运行状况的全面监控和管理,实现了能源节约、安全保障和舒适体验的多重目…

关于拖拽时需要注意的细节

cklick,mousedown,mouseup 当触发点击事件后三者的触发顺序 当元素放大用scalse时&#xff0c;检测鼠标的移动距离用不用/scale&#xff1f; <!doctype html> <html lang"en"><head><meta charset"UTF-8" /><link rel"ic…

【专题】智启未来:新质生产力引擎驱动下的智能制造行业革新报告合集PDF分享(附原数据表)

原文链接&#xff1a; https://tecdat.cn/?p37856 在当今全球经济格局深刻变革的大背景下&#xff0c;制造业作为国家经济的基石&#xff0c;正处在高质量发展的关键历史时期。智能决策作为一股崭新的力量&#xff0c;正逐步成为推动制造业数智化转型的强大新动能。众多制造企…