[发明专利]一种多租户数据库管控方法、系统及存储介质在审
申请号: | 202110789014.6 | 申请日: | 2021-07-13 |
公开(公告)号: | CN113535723A | 公开(公告)日: | 2021-10-22 |
发明(设计)人: | 王雷;范渊;黄进 | 申请(专利权)人: | 杭州安恒信息技术股份有限公司 |
主分类号: | G06F16/22 | 分类号: | G06F16/22;G06F16/2455;G06F16/25;G06F9/445;G06F9/455 |
代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 纪志超 |
地址: | 310000 浙江省*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 租户 数据库 方法 系统 存储 介质 | ||
1.一种多租户数据库管控方法,其特征在于,包括:
网络服务模块将租户端的多租户数据库管控请求发送至数据库接入模块,以使所述数据库接入模块确定所述多租户数据库管控请求对应的多租户数据库管控语句;
MyBatis拦截器对所述多租户数据库管控语句进行拦截,向租户上下文容器获取所述租户端的租户ID,并根据预设隔离模式将所述租户ID添加至所述多租户数据库管控语句中,以使所述数据库接入模块根据所述预设隔离模式,利用完成信息添加的多租户数据库管控语句在所述租户ID对应的数据库区域执行数据库操作;所述租户上下文容器中缓存有所述租户端的租户ID。
2.根据权利要求1所述的多租户数据库管控方法,其特征在于,所述数据库接入模块根据所述预设隔离模式,利用完成信息添加的多租户数据库管控语句在所述租户ID对应的数据库区域执行数据库操作,包括:
当所述预设隔离模式为完全隔离模式时,所述数据库接入模块利用所述完成信息添加的多租户数据库管控语句查找所述租户ID对应的目标数据库,并在所述目标数据库中执行所述数据库操作;
当所述预设隔离模式为半隔离模式时,所述数据库接入模块利用所述完成信息添加的多租户数据库管控语句查找所述租户ID对应的目标数据表,并在所述目标数据表中执行所述数据库操作;
当所述预设隔离模式为完全共享模式时,所述数据库接入模块利用所述完成信息添加的多租户数据库管控语句查找所述租户ID对应的数据,并对所述数据执行所述数据库操作。
3.根据权利要求1所述的多租户数据库管控方法,其特征在于,当所述网络服务模块为微服务时,还包括:
网络服务模块确定所述租户端所需调用的下一级微服务,生成远程调用请求并将所述远程调用请求发送至所述下一级微服务;
链路传参器在拦截到所述远程调用请求时,向所述租户上下文容器获取所述租户ID,并将所述租户ID添加至所述远程调用请求中;
所述链路传参器将完成信息添加的远程调用请求发送至所述下一级微服务。
4.根据权利要求1所述的多租户数据库管控方法,其特征在于,在根据预设隔离模式将所述租户ID添加至所述多租户数据库管控语句中之前,还包括:
所述MyBatis拦截器确定所述多租户数据库管控语句所属的多租户数据库管控方法是否配置有多租户指示器注解;
若是,则执行所述根据预设隔离模式将所述租户ID添加至所述多租户数据库管控语句中的步骤。
5.根据权利要求1所述的多租户数据库管控方法,其特征在于,还包括:
所述租户上下文容器利用Servlet过滤器获取所述租户端的Servlet请求;
从所述Servlet请求的请求头中获取所述租户ID并存储。
6.根据权利要求1至5任一项所述的多租户数据库管控方法,其特征在于,在网络服务模块将租户端的多租户数据库管控请求发送至数据库接入模块之前,还包括:
Spring容器获取所述网络服务模块的配置文件,并根据所述配置文件中的多租户开关配置项,判断所述网络服务模块是否开启多租户模式;
若是,根据所述配置文件中的路由类型配置所述MyBatis拦截器,并自动载入所述租户上下文容器、所述数据库接入模块及所述网络服务模块;
若否,则自动载入所述数据库接入模块及所述网络服务模块。
7.根据权利要求6所述的多租户数据库管控方法,其特征在于,所述根据所述配置文件中的路由类型配置所述MyBatis拦截器,包括:
所述Spring容器根据所述路由类型反射加载对应的路由配置类,并利用所述路由配置类自动配置所述MyBatis拦截器。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州安恒信息技术股份有限公司,未经杭州安恒信息技术股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110789014.6/1.html,转载请声明来源钻瓜专利网。