MyBatis利用MyCat实现多租户的简单思路分享

所属分类: 软件编程 / java 阅读数: 30
收藏 0 赞 0 分享

前言

本文的多租户是基于多数据库进行实现的,数据是通过不同数据库进行隔离。下面话不多说,来看看详细的介绍:

MyCat 基本配置

首先针对多租户配置了多个数据库,在 MyCat 的 schema.xml 中配置了多个 schema。

在 server.xml 中配置了一个用户:

后面会使用 MyCat 注解(就是注释)方式根据不同的标识,将操作指向不同的数据库。

过滤器识别请求匹配对应的数据库

标识有很多种方式可以加以区分,下面使用最简单的一种,通过不同的二级域名进行识别。二级域名和数据库对应的信息可以通过全局库或者公共库进行存储,还可以是简单的配置文件进行配置,不过下面代码只是为了演示,因此配置信息都是写死在代码中的。

假设存在以下二级域名,分别对应不同的数据库:

  • ui1.mybatis.tk :UI1
  • ui2.mybatis.tk :UI2
  • ui3.mybatis.tk :UI3

通过过滤器,在用户请求时根据请求地址设置当前请求使用的数据库:

这段代码只是很简单的判断,根据不同的字符串设置不同的数据库。使用了一个静态的本地线程变量来存储数据库信息。

重写 MyBatis 的 MappedStatement 简单实现 MyCat 注解

使用 MyBatis 和数据库进行操作时,所有执行的 sql 都是通过 MappedStatement 获取的,虽然通过拦截器方式也能给 sql 添加注解,但是实现起来有点复杂。通过重写 MappedStatement 会简单很多,但是你也需要保证重写的这个类能够替代默认的类。

重写很简单,只需要修改原有的 getBoundSql 方法:

这段代码就是在返回 BoundSql 前,修改 sql,添加 /*!mycat:schema=数据库*/,具体的数据库从过滤器的静态方法获取,由于每一个请求都会经过过滤器(特别注意,如果是任务一类的调用,不需要经过过滤器,这种情况需要处理任务执行时数据库的绑定,这需要根据具体业务实现),因此这里的操作一定能获取到具体的数据库。增加这个注解后,MyCat 执行时就会自动将数据库的操作发送到指定的数据库上执行,通过这种方式就实现了一种简单的多租户方式。

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

更多精彩内容其他人还在看

Java的面向对象编程基本概念学习笔记整理

这篇文章主要介绍了Java的面向对象编程基本概念学习笔记整理,包括类与方法以及多态等支持面向对象语言中的重要特点,需要的朋友可以参考下
收藏 0 赞 0 分享

Eclipse下编写java程序突然不会自动生成R.java文件和包的解决办法

这篇文章主要介绍了Eclipse下编写java程序突然不会自动生成R.java文件和包的解决办法 的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

基于Java实现杨辉三角 LeetCode Pascal's Triangle

这篇文章主要介绍了基于Java实现杨辉三角 LeetCode Pascal's Triangle的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Java中Spring获取bean方法小结

Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架,如何在程序中获取Spring配置的bean呢?下面通过本文给大家介绍Java中Spring获取bean方法小结,对spring获取bean方法相关知识感兴趣的朋友一起学习吧
收藏 0 赞 0 分享

如何计算Java对象占用了多少空间?

在Java中没有sizeof运算符,所以没办法知道一个对象到底占用了多大的空间,但是在分配对象的时候会有一些基本的规则,我们根据这些规则大致能判断出来对象大小,需要的朋友可以参考下
收藏 0 赞 0 分享

剖析Java中的事件处理与异常处理机制

这篇文章主要介绍了Java中的事件处理与异常处理机制,讲解Java是如何对事件或者异常作出响应以及定义异常的一些方法,需要的朋友可以参考下
收藏 0 赞 0 分享

详解Java的Struts2框架的结构及其数据转移方式

这篇文章主要介绍了详解Java的Struts2框架的结构及其数据转移方式,Struts框架是Java的SSH三大web开发框架之一,需要的朋友可以参考下
收藏 0 赞 0 分享

Java封装好的mail包发送电子邮件的类

本文给大家分享了2个java封装好的mail包发送电子邮件的类,并附上使用方法,小伙伴们可以根据自己的需求自由选择。
收藏 0 赞 0 分享

在Java的Struts中判断是否调用AJAX及用拦截器对其优化

这篇文章主要介绍了在Java的Struts中判断是否调用AJAX及用拦截器对其优化的方法,Struts框架是Java的SSH三大web开发框架之一,需要的朋友可以参考下
收藏 0 赞 0 分享

java多线程Future和Callable类示例分享

JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。其中前两种方式线程执行完后都没有返回值,只有最后一种是带返回值的。今天我们就来研究下Future和Callab
收藏 0 赞 0 分享
查看更多