多租户功能

2024-09-04 12:28
文章标签 功能 租户

本文主要是介绍多租户功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

多租户功能是基于租户共享同一个数据库、同一个表,但在表中通过tenant_id区分租户的数据的模式,基于mybatis-plus的多租户SQL解析器实现,如果对mybatis-plus不了解,请先看官方文档:https://mybatis.plus/guide/interceptor-tenant-line.html

租户功能说明

  • 一个租户就是一个商城,一个商城下可以有app、小程序、h5等多个展示端,同一租户下的不同端查出的数据是相同的
  • 有租户约束的情况下,各租户的数据相互隔离,用户只能管理自己所属租户的数据,没有租户信息约束的表除外
  • 自动维护租户ID,不需要手动处理,即可实现通过租户ID 过滤的效果
  • 表中添加 tenant_id 字段
  • 在nacos相应服务的配置文件中维护这张表即可(例如以下微信模块的配置文件:lun-weixin-admin-dev.yml,其他模块同理)
# 租户表维护
base:tenant:column: tenant_idtables:- wx_app- wx_menu- wx_user- wx_auto_reply- wx_msg- wx_mass_msg

后台租户ID自动维护

  • 通过TenantContextHolderFilter拦截器,获取到token在redis中的租户ID 放到theadlocal 中

前端api租户ID自动维护

  • 通过ThirdSessionInterceptor拦截器,获取到thirdSession在redis中的租户ID 放到theadlocal 中

无租户ID场景

  • 不需要租户信息约束的方法,在mapper的方法上添加注解旧版:@SqlParser(filter=true)新版:@InterceptorIgnore(tenantLine="true"),加上这个注解后mybatisPlus就不会在这个sql自动维护租户ID了
旧版
@SqlParser(filter=true)
SysUser getByNoTenant(SysUser sysUser);
新版
@InterceptorIgnore(tenantLine="true")
SysUser getByNoTenant(SysUser sysUser);
  • 有些没有token或thirdSession但又需要租户的场景,比如订单支付回调是不会有token和thirdSession的,所以系统不会自动维护;此时我们可以先通过回调传过来的appId,去做无租户约束的查询获取到租户ID,再手动维护进去TenantContextHolder.setTenantId

获取当前租户

TenantContextHolder.getTenantId

强制切换租户

TenantContextHolder.setTenantId

注:在增删改过程中请勿对 tenant_id字段手动赋值,不然报错

租户表维护

机构表sys_organ中parent_id为0的机构默认为一个租户

这篇关于多租户功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

基于SpringBoot实现文件秒传功能

《基于SpringBoot实现文件秒传功能》在开发Web应用时,文件上传是一个常见需求,然而,当用户需要上传大文件或相同文件多次时,会造成带宽浪费和服务器存储冗余,此时可以使用文件秒传技术通过识别重复... 目录前言文件秒传原理代码实现1. 创建项目基础结构2. 创建上传存储代码3. 创建Result类4.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专