控制台程序中实现一个连接一个DBContext实例
admin
2024-01-18 19:51:50
0

最近在控制台程序中使用EFCore,并使用了依赖注入的方式注册调用,但测试时发现不同客户端连接对应了同一个DBContext,导致并发出现问题。踩得坑记录一下。

在ASP.NET Core应用程序中使用EF Core的基本模式通常包括将自定义DbContext类型注册到依赖项注入系统中,然后通过控制器中的构造函数参数获取该类型的实例。这意味着将为每个请求创建一个新的DbContext实例。

public void ConfigureServices(IServiceCollection services)
{services.AddDbContext(options => options.UseSqlServer(connectionString));}public class TiketsController : ControllerBase
{private readonly MCContext _context;public TiketsController (MCContext context){_context = context;}}

但是 AddDbContext方法对应的服务生命周期是 Scoped,这样在控制台程序中使用会有一个问题,如果控制台提供一个服务,客户端不同的连接对应的都是一个Context,这样存在并发的问题,如果有个语句出错了,后面操作都将报错。

有AddSingleton、AddScoped、AddTransient 三种方式注册服务,对应的生命周期如下:

  1、Transient:每次从容器 (IServiceProvider)中获取的时候都是一个新的实例

  2、Singleton:每次从同根容器中(同根 IServiceProvider)获取的时候都是同一个实例

  3、Scoped:每次从同一个容器中获取的实例是相同的、

所以在控制台中要用AddTransient的方法注册DbContext:

var Services = new ServiceCollection().AddTransient((c) =>{var optionsBuilder = new DbContextOptionsBuilder();optionsBuilder.UseMySql(connStr, ServerVersion.AutoDetect(connStr)).LogTo(Console.WriteLine, LogLevel.Information).EnableSensitiveDataLogging().EnableDetailedErrors();//如果有其他依赖的话,可以通过provider.GetService()来获取return new DbContext(optionsBuilder.Options);}).BuildServiceProvider();

如果用AddSingleton方法写法:

 var Services = new ServiceCollection().AddSingleton>(() =>{var optionsBuilder = new DbContextOptionsBuilder();optionsBuilder.UseMySql(connStr, ServerVersion.AutoDetect(connStr)).LogTo(Console.WriteLine, LogLevel.Information).EnableSensitiveDataLogging().EnableDetailedErrors();//如果有其他依赖的话,可以通过provider.GetService()来获取return new DbContext(optionsBuilder.Options);}).BuildServiceProvider();

参考:

解析 .Net Core 注入——注册服务 | 服务 (lmlphp.com)

(14条消息) EF Core之DBContext生命周期_2Ker的博客-CSDN博客_adddbcontext 生命周期

在ASP.Net Core中每个请求一次创建EF Core上下文 | (1r1g.com)

相关内容

热门资讯

安卓和ios的系统比较,性能、... 你有没有想过,为什么你的手机里装的是安卓系统而不是iOS呢?或者,你有没有好奇过,为什么有些人对安卓...
安卓系统修复软件下载,重拾流畅... 手机里的安卓系统突然卡壳了,是不是让你头疼不已?别急,今天就来给你支个招,告诉你怎么下载一款超级好用...
安卓系统微信数据导入,畅享无缝... 你有没有想过,当你从旧手机换到新手机时,那些珍贵的微信聊天记录怎么才能无缝迁移呢?别急,今天就来给你...
安卓手机系统延迟通知,揭秘背后... 你有没有发现,有时候安卓手机上的通知延迟了,让人等得心痒痒的?这可真是让人头疼的小麻烦啊!今天,就让...
安卓精简系统没法定位,定位功能... 你有没有遇到过这种情况?手机里装了个安卓精简系统,结果定位功能竟然失灵了!这可真是让人头疼不已。今天...
腾讯可以退款嘛安卓系统,轻松解... 你有没有遇到过在安卓系统上使用腾讯软件时,突然觉得不合适或者不满意,想要退款的情况呢?这可真是个让人...
安卓系统有c盘吗,揭秘“C盘”... 你有没有想过,你的安卓手机里有没有一个神秘的C盘呢?是不是觉得这个问题有点奇怪?别急,让我来给你揭秘...
免费安卓点名系统源码,轻松实现... 你有没有想过,在繁忙的课堂中,如何轻松管理学生出勤呢?别急,今天就来给你揭秘一个神器——免费安卓点名...
安卓系统有哪些牌子好,这些优质... 说到安卓系统,这可是现在手机市场上的大热门呢!你有没有想过,这么多牌子,哪个才是最适合你的呢?别急,...
安卓4.3精简系统列表,极致性... 你有没有想过,你的安卓手机其实可以更轻快、更流畅呢?没错,就是那个你可能从未听说过的安卓4.3精简系...
用终端备份安卓系统,轻松掌握安... 你有没有想过,如果你的安卓手机突然间像顽皮的小猫一样,把你的照片、视频和重要文件都藏了起来,你会怎么...
各安卓系统区别在哪,各版本特色... 你有没有发现,手机里的安卓系统好像各有各的特色,让人眼花缭乱?今天,就让我带你来一场安卓系统的“大揭...
安卓刷谷歌原生系统,谷歌原生系... 你有没有想过,你的安卓手机是不是也能像那些高端旗舰一样,拥有流畅的原生系统体验呢?没错,今天就要来给...
安卓系统下载ea游戏,安卓系统... 你有没有发现,安卓手机上的游戏世界简直是个宝库啊!尤其是那些经典的EA游戏,比如《FIFA》、《战地...
电子基盘原版安卓系统,创新与融... 你有没有想过,为什么你的手机总是那么卡,而别人的手机却流畅得像风一样?其实,这背后有一个神秘的角色—...
海信电视安卓系统设置,畅享智能... 亲爱的电视迷们,你是否在享受海信电视带来的视觉盛宴时,也想要深入探索一下它的安卓系统设置,让它更加贴...
安卓13系统以上的机型,引领未... 你知道吗?最近手机圈可是热闹非凡呢!安卓13系统已经悄然上线,而且听说只有那些最新的机型才能享受到这...
安卓系统恢复视力app,重拾清... 你是不是也和我一样,长时间盯着手机屏幕,眼睛干涩得像沙漠里的仙人掌?别担心,今天我要给你介绍一款神奇...
安卓调用系统ping码,And... 你有没有想过,你的安卓手机里那些看似普通的代码,其实藏着大大的秘密呢?今天,就让我带你一探究竟,揭开...
如何考备安卓系统,全面解析考试... 你有没有想过,想要在手机上玩那些炫酷的安卓游戏,或者开发自己的安卓应用,是不是得先学会怎么备考安卓系...