SaaS系统的销售微服务与权限微服务边界设计

news2025/3/21 23:06:15

       在设计SaaS系统的销售微服务与权限微服务的边界时,需要结合领域驱动设计(DDD)和微服务拆分原则,确保高内聚、低耦合。以下是结合微服务架构原则、多租户SaaS需求及权限管理场景的完整设计方案,整合了权限服务与销售服务的边界划分、订阅生命周期管理等核心模块。

一、整体架构设计

1、架构原则​

  • 服务自治性:每个微服务独立部署、独立数据库,遵循单一职责原则。
  • 多租户支持:采用字段级隔离,通过tenant_id区分企业数据。
  • ​通信方式:REST API用于同步调用(如鉴权),RocketMQ用于异步事件(如订阅到期通知)。

2、服务划分

微服务核心职责
销售服务产品套餐管理、订单处理、订阅生命周期(创建/续费/到期)、计费策略。
权限服务功能权限管理(RBAC)、租户-功能有效期映射、鉴权(JWT/OAuth2.0)
网关服务统一入口、路由分发、请求限流

 二、核心模块设计

1、​订阅与权限联动机制

(1)订阅状态管理(销售服务)

  • 订阅生命周期管理​(到期、续费、失效),维护订阅表,记录企业购买的功能模块、有效期。
  • 定时任务每日扫描到期订阅,触发订阅到期事件通知权限服务。

(2)权限状态同步(权限服务)​

  • ​监听到期事件,消费RocketMQ事件,更新租户功能有效期映射表(租户ID、功能模块、到期时间)。
  • 鉴权时双重校验(​RBAC校验、订阅校验):检查用户角色是否关联功能、查询租户功能有效期,拦截过期请求。

2、多租户权限模型

(1)​功能隔离

         通过功能表的字段区分不同功能包,销售服务将功能包与企业订阅关联。

(2)数据隔离

         所有表增加tenant_id字段。

3、关键接口定义

服务接口示例用途
销售服务POST /api/sales/subscription创建订阅
权限服务POST /api/auth/check实时鉴权
网关服务

路由规则:/api/sales/** → 销售服务,

      /api/auth/** → 权限服务

动态路由与负载均衡

 ​三、数据流与事件驱动

1、创建订阅处理流程

     (1)用户浏览产品版本及功能列表。

     (2)创建订单,支付成功后创建订阅记录。

     (3)支付成功,创建订阅记录。

     (4)订阅生效,通知权限服务更新租户功能有效期表。

2、订阅到期处理流程

     (1)订阅到期判断(销售微服务)​。通过定时任务(如每天凌晨)扫描订阅表的订阅到期字段,标记到期企业。

     (2)发布订阅状态事件(销售微服务)​。当订阅到期/续费时,销售服务发送事件到消息队列。

     (3)权限状态更新(权限微服务)​。权限服务消费事件,更新数据库中的企业功能有效期表​。

3、用户访问拦截流程

      (1)用户请求通过网关路由至权限服务。

      (2)权限服务解析JWT令牌获取tenant_id和user_id。

      (3)查询RBAC权限表和租户有效期表。

      (4)拦截逻辑:无权限或者功能已过期返回403。

四、安全与监控设计

1、安全策略

  • ​API鉴权:网关统一验证JWT令牌,权限服务细粒度控制功能访问。
  • ​数据加密:敏感字段(如支付信息)采用AES加密存储。
  • ​防攻击:网关集成Sentinel防DDoS,SQL注入拦截基于MyBatis参数化查询。

2、可观测性

  • 监控:Prometheus采集服务指标(如鉴权接口QPS),Grafana可视化仪表盘。
  • ​日志:ELK集中管理日志,通过tenant_id快速定位企业级问题。

        通过销售服务管理订阅生命周期、权限服务执行动态鉴权,结合事件驱动与多租户隔离策略,实现了SaaS系统核心功能。

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

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

相关文章

leetcode热题100道——两数之和

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。 你可以按任意顺序返回答案。 示例 1…

Git远程拉取和推送配置

Git进行远程代码拉取和推送时候提示配置user.name 和 user.email 背景:换新电脑后使用Git进行代码拉取和推送过程中,提示“Make sure you configure your “user.name” and “user.email” in git.”。这个配置针对git的正常使用仅需要配置一次&#xf…

基于SpringBoot+Vue3实现的宠物领养管理平台功能七

一、前言介绍: 1.1 项目摘要 随着社会经济的发展和人们生活水平的提高,越来越多的人开始关注并参与到宠物领养中。宠物已经成为许多家庭的重要成员,人们对于宠物的关爱和照顾也日益增加。然而,传统的宠物领养流程存在诸多不便&a…

调研报告:Hadoop 3.x Ozone 全景解析

Ozone 是 Hadoop 的分布式对象存储系统,具有易扩展和冗余存储的特点。 Ozone 不仅能存储数十亿个不同大小的对象,还支持在容器化环境(比如 Kubernetes)中运行。 Apache Spark、Hive 和 YARN 等应用无需任何修改即可使用 Ozone。Ozone 提供了 Java API、S3 接口和命令行接口…

【Linux】Makefile秘籍

> 🍃 本系列为Linux的内容,如果感兴趣,欢迎订阅🚩 > 🎊个人主页:【小编的个人主页】 >小编将在这里分享学习Linux的心路历程✨和知识分享🔍 >如果本篇文章有问题,还请多多包涵&a…

玩转物联网-4G模块如何快速将数据上传到巴法云(TCP篇)

目录 1 前言 2 环境搭建 2.1 硬件准备 2.2 软件准备 2.3 硬件连接 2.4 检查驱动 3 巴法云平台设备创建 3.1 创建账号 3.2 进入巴法云 3.3 获取联网参数 4 连接巴法云 4.1 打开配置工具读取基本信息 4.2 设置连接参数进行数据交互 4.2.1 建立TCP连接 4.2.2 订阅主题 4.2.3 发布信…

vue3+ts心得

1、Vue3核心 1、setup setup里弱化this,return可以返回函数,返回后页面也显示那个函数值 data里面是可以用this.来获取setup里的值,这个是单向的 vue3两个script标签不要觉得奇怪,一个是配置组合式api的,一个是配置组…

SQLark中如何进行数据筛选与排序

本文将为你介绍在 SQLark 中如何进行数据筛选与排序,掌握这些操作能够极大提升你的工作效率。 SQLark官网链接:www.sqlark.com 数据筛选 在数据库操作中,数据筛选是一项关键功能,它依据特定条件对数据进行过滤,帮助用户从海量数据…

VSTO(C#)Excel开发11:自定义任务窗格与多个工作簿

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的,可以在任何平台上使用。 源码指引:github源…

vscode查看文件历史git commit记录

方案一:GitLens 在vscode扩展商店下载GitLens 选中要查看的文件,vscode界面右上角点击GitLens的图标,选择Toggle File Blame 界面显示当前打开文件的所有修改历史记录 鼠标放到某条记录上,可以看到记录详情,选中O…

GaussDB备份数据常用命令

1、常用备份命令gs_dump 说明:是一个服务器端工具,可以在线导出数据库的数据,这些数据包含整个数据库或数据库中指定的对象(如:模式,表,视图等),并且支持导出完整一致的数…

数学建模 第三节

目录 前言 一 钻井布局问题 第一问分析 第二问分析 总结 前言 这里讲述99年的钻井布局问题,利用这个问题讲述模型优化,LINGO,MATLAB的使用 一 钻井布局问题 这个是钻井布局的原题,坐标的位置为 a [0.50,1.41,3.00,3.37,3…

算法系列——有监督学习——3.逻辑回归

一、概述 逻辑回归是一种学习某个事件发生概率的算法。利用这个概率,可以对某个事件发生或不发生进行二元分类。虽然逻辑回归本来是二元分类的算法,但也可以用于三种类别以上的分类问题。为了理解这个算法,请思考以下例子。 你在回家的路上发…

深入理解traceroute命令及其原理

traceroute 是一个网络诊断工具(Windows上叫tracert),用于显示数据包从本地主机到远程主机经过的路由(跳数)。它可以帮助您了解数据包在网络中的传输路径,以及每跳的延迟情况。这对于网络故障排除、分析网络…

前后端联调解决跨域问题的方案

引言 在前后端分离的开发模式中,前端和后端通常在不同的服务器或端口运行,这样就会面临跨域问题。跨域问题是指浏览器因安全限制阻止前端代码访问与当前网页源不同的域、协议或端口的资源。对于 Java 后端应用,我们可以通过配置 CORS&#x…

【vue2 + Cesium】相机视角移动+添加模型、模型点击事件

参考文章:vue2 使用 cesium 【第二篇-相机视角移动添加模型】 这篇文章在上篇文章的基础上继续开发,主要实现效果 相机视角移动 添加模型 点击事件 上篇文章:【vue2 Cesium】使用Cesium、添加第三方地图、去掉商标、Cesium基础配置、地…

【AI】AI编程助手:Cursor、Codeium、GitHub Copilot、Roo Cline、Tabnine

文章目录 一、基本特性对比二、收费标准三、私有部署能力1、Tabnine2、Roo Code 三、代码补全与自然语言生成代码四、安装独立的IDE安装插件安装 五、基本使用(一)Cursor(二)GitHub Copilot1、获取代码建议2.聊天1)上下…

我的uniapp自定义模板

uniapp自定义模板 如有纰漏请谅解,以官方文档为准后面这段时间我会学习小程序开发的知识,会持续更新可以查看我的github,后续我会上传我的uniapp相关练习代码有兴趣的话可以浏览我的个人网站,我会在上面持续更新内容,…

【C++】动态规划从入门到精通

一、动态规划基础概念详解 什么是动态规划 动态规划(Dynamic Programming,DP)是一种通过将复杂问题分解为重叠子问题,并存储子问题解以避免重复计算的优化算法。它适用于具有以下两个关键性质的问题: 最优子结构&…

OpenCV计算摄影学(23)艺术化风格化处理函数stylization()

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 风格化的目的是生成不以照片写实为目标的多种多样数字图像效果。边缘感知滤波器是风格化处理的理想选择,因为它们能够弱化低对比度区…