druid-multi-tenant-starter将系统改造成多租户系统如此简单
项目开源地址 https://github.com/osinn/druid-multi-tenant-starter ,如果对您有帮助,麻烦给个Star
多租户插件 druid-multi-tenant-starter 的出现为系统的改造成多租户带来了前所未有的便捷。它以其独特的优势和强大的功能,使得将系统改造成多租户系统变得如此简单。
从技术层面来看,druid-multi-tenant-starter 它能够处理租户之间的数据隔离和资源分配,确保每个租户都能享受到独立且稳定的服务,迅速将原本复杂的单一系统升级为多租户系统,大大提高了系统的灵活性和可扩展性。不仅能够轻松应对业务的快速增长,还降低了运营成本和维护难度,无论您的系统规模大小、业务类型如何,它都能为您提供高效、可靠的多租户解决方案,多租户插件 druid-multi-tenant-starter 确实让系统向多租户系统的改造变得轻而易举,为企业的数字化转型之路注入了强大的动力。
此外,多租户插件 druid-multi-tenant-starter 支持jdk1.8+、Spring boot2.x以及兼容Spring boot 3.x版本
单一系统改造成多租户系统演示
首先在数据库中将所有表都加上租户ID,例如字段名称为 tenant_id
DELIMITER $$
CREATE PROCEDURE AddColumnToAllTables(p_column_name VARCHAR(255))
BEGIN
DECLARE v_table_name VARCHAR(255);
DECLARE table_cursor CURSOR FOR
SELECT table_name FROM information_schema.tables WHERE table_schema = (SELECT DATABASE()) AND table_type = 'BASE TABLE';
DECLARE CONTINUE HANDLER FOR NOT FOUND SET v_table_name = NULL;
OPEN table_cursor;
read_loop: LOOP
FETCH table_cursor INTO v_table_name;
IF v_table_name IS NULL THEN
LEAVE read_loop;
END IF;
SET @stmt = CONCAT('ALTER TABLE `', v_table_name, '` ADD COLUMN `', p_column_name, "` bigint(20) DEFAULT NULL COMMENT '租户Id'");
PREPARE s1 FROM @stmt;
EXECUTE s1;
DEALLOCATE PREPARE s1;
END LOOP;
CLOSE table_cursor;
END$$
DELIMITER ;
CALL AddColumnToAllTables('tenant_id');
- 以上sql脚本会将所有表加上 tenant_id 字段
项目中引入插件依赖包
<dependency>
<groupId>io.github.osinn</groupId>
<artifactId>druid-multi-tenant-starter</artifactId>
<version>最新版本</version>
</dependency>
项目配置
- 在yml配置文件中添加以下配置来启用多租户插件
mybatis:
tenant:
config:
# 是否启用多租户插件
enable: true
# 数据库表中租户ID的字段名
tenant-id-column: tenant_id
实现提供获取多租户值接口
/**
* 演示:提供多租户ID服务接口
*
* @author wency_cai
*/
@Service
public class TenantServiceImpl implements ITenantService<Integer>{
@Override
public List<Integer> getTenantIds() {
// 开发者需要自己实现获取系统多租户id值的代码逻辑,如果有多个返回多个值即可
int tenantId = 1;
return Lists.newArrayList(tenantId);
}
}
- 到此为止已经将系统改造成多租户系统,租户之间的数据隔离
- 更多的功能请在github上查看文档
单一系统升级为多租户系统就是这么简单,very good