全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

EF Core连接弹性怎么配置 EF Core EnableRetryOnFailure方法

EF Core连接弹性通过EnableRetryOnFailure自动重试暂时性故障,默认6次指数退避重试,支持SQL Server/PostgreSQL/MySQL;事务需用CreateExecutionStrategy手动包装;连接字符串应配置ConnectRetryCount等参数分层防护。

EF Core 的连接弹性(Connection Resiliency)核心是自动重试因网络抖动、数据库瞬时不可用等导致的暂时性故障。最直接有效的配置方式就是使用 EnableRetryOnFailure 方法,它会为 DbContext 启用内置的重试执行策略。

基础启用方式(推荐默认用法)

对 SQL Server、PostgreSQL(Npgsql)、MySQL(Pomelo)等主流提供程序,只需在配置 DbContext 时调用 EnableRetryOnFailure() 即可启用默认策略:

  • SQL Server 默认识别错误码如 40613、40197、1205 等;
  • PostgreSQL 识别 08006、08001 等连接类错误;
  • 默认重试次数为 6 次,延迟采用指数退避(1s → 2s → 4s → …);
  • 无需额外判断异常类型,框架自动过滤非暂时性错误(如主键冲突、语法错误)。

示例(ASP.NET Core 中注册 DbContext):

services.AddDbContext(options =>
  options.UseSqlServer(connectionString, sqlOptions =>
    sqlOptions.EnableRetryOnFailure()));

自定义重试参数

当默认策略不满足业务场景(比如云环境波动大、或需更激进/保守的重试),可显式指定参数:

  • maxRetryCount:最大重试次数(默认 6,建议设为 5–10);
  • maxRetryDelay:单次最大延迟(默认 30 秒,避免长等待阻塞请求);
  • errorNumbersToAdd:补充自定义可重试的 SQL 错误号(如 SQL Server 的 2、53、10054);
  • 注意:errorNumbersToAdd 是“追加”,不是“替换”——原有默认错误仍生效。

示例(自定义 8 次重试,最长延迟 20 秒):

options.UseSqlServer(conn, o => o.EnableRetryOnFailure(
  maxRetryCount: 8,
  maxRetryDelay: TimeSpan.FromSeconds(20),
  errorNumbersToAdd: new[] { 2, 53 }));

事务中必须手动包装重试逻辑

启用了 EnableRetryOnFailure 后,普通查询和 SaveChangesAsync() 会自动重试。但一旦你显式开启事务(BeginTransactionAsync()),EF 就无法安全重试整个事务块——因为部分操作可能已提交。

  • 此时若在事务内发生暂时性错误,会抛出 InvalidOperationException:“已配置的执行策略不支持用户启动的事务”;
  • 正确做法:用 DbContext.Database.CreateExecutionStrategy() 获取执行策略,把整个事务逻辑包进委托里执行;
  • 该策略会在失败时完整重放整个委托(含 BeginTransaction → SaveChanges → Commit),确保原子性。

连接字符串级补充配置(配合使用)

EnableRetryOnFailure 处理的是命令执行阶段的失败,而连接建立阶段的弹性还需靠连接字符串参数:

  • ConnectRetryCount=5:驱动层连接尝试次数(ADO.NET 层);
  • ConnectRetryInterval=10:每次重连间隔(秒);
  • Connection Timeout=30:单次连接超时,避免卡死;
  • 这两类机制(驱动层连接重试 + EF 命令重试)建议同时启用,形成双保险。

例如连接字符串片段:
Server=...;Database=...;ConnectRetryCount=5;ConnectRetryInterval=10;Connection Timeout=30;

基本上就这些。关键不是堆参数,而是理解重试边界——普通操作开箱即用,事务要手动兜底,连接建立和命令执行要分层防护。


# mysql  # ai  # nas  # sqlserver  # .net  # sql  # 字符串  #   # 委托  # database  # postgresql  # 数据库  # 重试  # 自定义  # 的是  # 只需  # 设为  # 会在  # 不支持  # 会为  # 还需  # 两类 


相关文章: 建站主机默认首页配置指南:核心功能与访问路径优化  制作网站外包平台,自动化接单网站有哪些?  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  广州营销型建站服务商推荐:技术优势与SEO优化解析  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  建站主机SSH密钥生成步骤及常见问题解答?  建站之星如何一键生成手机站?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  企业微网站怎么做,公司网站和公众号有什么区别?  如何快速配置高效服务器建站软件?  正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?  如何通过PHP快速构建高效问答网站功能?  如何获取免费开源的自助建站系统源码?  如何快速登录WAP自助建站平台?  如何注册花生壳免费域名并搭建个人网站?  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  建站之星后台密码如何安全设置与找回?  家具网站制作软件,家具厂怎么跑业务?  如何在阿里云域名上完成建站全流程?  西安大型网站制作公司,西安招聘网站最好的是哪个?  如何用虚拟主机快速搭建网站?详细步骤解析  c# Task.ConfigureAwait(true) 在什么场景下是必须的  如何在宝塔面板创建新站点?  建站之星安装需要哪些步骤及注意事项?  外贸公司网站制作,外贸网站建设一般有哪些步骤?  网站网页制作专业公司,怎样制作自己的网页?  青岛网站建设如何选择本地服务器?  制作证书网站有哪些,全国城建培训中心证书查询官网?  教程网站设计制作软件,怎么创建自己的一个网站?  教育培训网站制作流程,请问edu教育网站的域名怎么申请?  如何通过VPS搭建网站快速盈利?  公众号网站制作网页,微信公众号怎么制作?  Swift中swift中的switch 语句  网站按钮制作软件,如何实现网页中按钮的自动点击?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  视频网站制作教程,怎么样制作优酷网的小视频?  盐城做公司网站,江苏电子版退休证办理流程?  如何高效利用亚马逊云主机搭建企业网站?  如何通过服务器快速搭建网站?完整步骤解析  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  内网网站制作软件,内网的网站如何发布到外网?  如何使用Golang table-driven基准测试_多组数据测量函数效率  Android自定义控件实现温度旋转按钮效果  外贸公司网站制作哪家好,maersk船公司官网?  如何用西部建站助手快速创建专业网站?  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  建站之星备案是否影响网站上线时间?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  C++用Dijkstra(迪杰斯特拉)算法求最短路径 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。