ShardingCore读写分离

该文介绍了如何利用ShardingCore在.NET5的Asp.NetCoreWebApi项目中进行数据库读写分离的配置,包括安装插件、配置主从数据库、创建项目、定义实体类和数据库上下文、在启动类中配置读写分离策略,并提供了在Controller中添加数据和查询数据的接口示例。还提到了通过Postman进行API测试以及如何在代码中切换读写库。
摘要由CSDN通过智能技术生成

1、安装插件

参考链接:ShardingCore安装笔记_Three Big Stones的博客-CSDN博客

2、配置主从数据库,具体步骤自行搜索查询

3、搭建项目

开发环境:Visual studio 项目模板:Asp.Net Core Web Api 框架:.Net5

4、添加实体类、数据库上下文

参考链接:ShardingCore分库实践_Three Big Stones的博客-CSDN博客

5、配置启动类

 在启动类中配置读写分离,具体参考如下代码:

using Microsoft.EntityFrameworkCore;
using ShardingCore;
using ShardingCore.Sharding.ReadWriteConfigurations;
using ShardingTableDemo;
var builder = WebApplication.CreateBuilder(args);

// Add services to the container.
builder.Services.AddShardingDbContext<MyDbContext>().UseRouteConfig(op =>
{
    op.AddShardingTableRoute<SysUserVirtualTableRoute>();
    op.AddShardingTableRoute<OrderVirtualTableRoute>();
}).UseConfig(op =>
{
    op.ThrowIfQueryRouteNotMatch = false;
    op.UseShardingQuery((conStr, bd) =>
    {
        bd.UseMySql(conStr, new MySqlServerVersion(new Version())).UseLoggerFactory(StartupExtension.efLogger);
    });
    op.UseShardingTransaction((connection, bd) =>
    {
        bd.UseMySql(connection, new MySqlServerVersion(new Version())).UseLoggerFactory(StartupExtension.efLogger);
    });
    op.AddDefaultDataSource("ds0", "Server=127.0.0.1;port=3306;user=root;password=panlei1990;database=yzwDb1;");
    op.AddReadWriteSeparation(sp =>//读写分离
    {
        return new Dictionary<string, IEnumerable<string>>
        {
            {"ds0",new List<string>(){"Server=127.0.0.1;port=3306;user=root;password=panlei1990;database=yzwDb2;","Server=127.0.0.1;port=3306;user=root;password=panlei1990;database=yzwDb1;"}}
        };
    }, ReadStrategyEnum.Random, true);//读取数据源随机选择从库连接
    //}, ReadStrategyEnum.Random, false);//读取数据源随机选择主库连接
    //}, ReadStrategyEnum.Loop, true);//依次循环选择从库连接
}).AddShardingCore();

builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();

var app = builder.Build();

app.UseAuthorization();

app.MapControllers();

using(var scope = app.Services.CreateScope())
{
    var myDbContext = scope.ServiceProvider.GetService<MyDbContext>();
    myDbContext.Database.EnsureCreated();
}
app.Services.UseAutoTryCompensateTable();
//app.InitSeed();
app.Run();

参数说明:

AddReadWriteSeparation:此方法用于添加读写分离配置项,可配置多个数据源

ReadStrategyEnum:Random枚举,表示随机读取一个数据源;Loop枚举,表示如果有多个数据源的话,将按顺序依次读取数据源。

defaultEnable:true默认读取从库,false默认读取主库

6、新建controller类

增加添加数据接口

[Route("AddOrder")]
        [HttpPost]
        public async Task<IActionResult> Add(Order order)
        {
            order.CreationTime = DateTime.Now;
            this.dbContext.Set<Order>().Add(order);
            var i = this.dbContext.SaveChanges();
            return Ok(i);
        }

增加查询数据接口

[Route("GetOrder")]
        public async Task<IActionResult> GetOrder(string id)
        {
            //this.dbContext.ReadWriteSeparationWriteOnly();//切换到写库
            var order = await this.dbContext.Set<Order>().FirstOrDefaultAsync(x => x.Id == id);
            return Ok(order);
        }

7、使用postman测试web api

在代码中切换到写库

this.dbContext.ReadWriteSeparationWriteOnly();//切换到写库

在代码中切换到读库

this.dbContext.ReadWriteSeparationReadOnly();//切换到读库

8、结束

读写分离关键点在于Program类中读写分离配置项的配置,以及各项参数的设置,不同的参数设置将会影响读写分离的具体执行策略。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值