详解在.net core中完美解决多租户分库分表的问题

2025-05-29 0 30

前几天有人想做一个多租户的平台,每个租户一个库,可以进行水平扩展,应用端根据登录信息,切换到不同的租户库

计划用ef core实现,他们说做不出来,需要动态创建dbContext,不好实现

然而这个使用CRL很轻松就能解决了

以下为演示数据库,有两个库testdb和testdb2,查询结果如下

详解在.net core中完美解决多租户分库分表的问题

详解在.net core中完美解决多租户分库分表的问题

目标:

根据传入登录信息连不不同的库,查询返回结果,如登录人为01,返回d1.default,登录人为02 返回 d2.default

实际上这个需求就是分库分表的实现,通过设置数据库/表映射关系,根据传入的定位数据进行匹配,找到正确的库表配置,生成数据访问对象

以core控制台程序为例

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33
class Program

{

static IServiceProvider provider;

static Program()

{

var services = new ServiceCollection();

services.AddCRL<DBLocationCreator>();

services.AddScoped<Code.Sharding.MemberManage>();

provider = services.BuildServiceProvider();

provider.UseCRL();

}

static void Main(string[] args)

{

label1:

var instance = provider.GetService<Code.Sharding.MemberManage>();

var data = new Code.Sharding.MemberSharding();

data.Code = "01";

instance.SetLocation(data);

var find1 = instance.QueryItem(b => b.Id > 0)?.Name;

Console.WriteLine($"定位数据输入{data.Code},查询值为{find1}");

data.Code = "02";

instance.SetLocation(data);

var find2 = instance.QueryItem(b => b.Id > 0)?.Name;

Console.WriteLine($"定位数据输入{data.Code},查询值为{find2}");

Console.ReadLine();

goto label1;

}

}

上面代码中,通过SetLocation方法传入定位数据Code,通过QueryItem方法查询出数据并打印出来

通过services.AddCRL<DBLocationCreator>()注入定位配置,DBLocationCreator继承了接口IDBLocationCreator

这里完全符合core注入规范,可以通过配置或数据库存储动态读取定位设置

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30
public class DBLocationCreator : IDBLocationCreator

{

ISettingConfigBuilder _settingConfigBuilder;

public DBLocationCreator(ISettingConfigBuilder settingConfigBuilder)

{

_settingConfigBuilder = settingConfigBuilder;

}

public void Init()

{

//自定义定位

_settingConfigBuilder.RegisterLocation<Code.Sharding.MemberSharding>((t, a) =>

{

var tableName = t.TableName;

var dbName = a.Code == "02" ? "testdb2" : "testdb";

var dataBase = $"Data Source=.;Initial Catalog={dbName};User ID=sa;Password=123";

//返回定位库和表名

return new CRL.Sharding.Location(dataBase, tableName);

});

_settingConfigBuilder.RegisterDBAccessBuild(dbLocation =>

{

var connectionString = "Data Source=.;Initial Catalog=testdb;User ID=sa;Password=123";

if (dbLocation.ShardingLocation != null)

{

connectionString = dbLocation.ShardingLocation.DataBaseSource;

}

return new CRL.DBAccessBuild(DBType.MSSQL, connectionString);

});

}

}

在Init方法里,实现了两个操作,通过RegisterLocation定义如何根据定位数据Code,返回不同的库/表

通过RegisterDBAccessBuild实现数据访问

运行测试程序,结果输出为

详解在.net core中完美解决多租户分库分表的问题

上面代码通过自定义定位参数和定位规则,没有任何耦合,调用也很简单,完美达到了预期效果

测试代码地址:https://github.com/CRL2020/CRL.NetStandard/tree/master/Test/CRLCoreTest

到此这篇关于详解在.net core中完美解决多租户分库分表的问题的文章就介绍到这了,更多相关.net core多租户分库分表内容请搜索快网idc以前的文章或继续浏览下面的相关文章希望大家以后多多支持快网idc!

原文链接:https://www.cnblogs.com/hubro/p/12693868.html

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 详解在.net core中完美解决多租户分库分表的问题 https://www.kuaiidc.com/97832.html

相关文章

发表评论
暂无评论