实现.Net7下数据库定时检查的方法详解

 更新时间:2022年12月20日 09:40:49   作者:Newbe36524  
在软件开发过程中,有时候我们需要定时地检查数据库中的数据,并在发现新增数据时触发一个动作。为了实现这个需求,本文我们在?.Net?7?下进行一次简单的演示。感兴趣的可以了解一下
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

在软件开发过程中,有时候我们需要定时地检查数据库中的数据,并在发现新增数据时触发一个动作。为了实现这个需求,我们在 .Net 7 下进行一次简单的演示。

PeriodicTimer

.Net 6 中新增了 PeriodicTimer 这个类,它可以用来创建一个定时器,以固定间隔的时间调用回调函数。使用方法如下:

using?var?timer?=?new?PeriodicTimer(TimeSpan.FromSeconds(10));
while?(await?timer.WaitForNextTickAsync())
{
????//Business?logic
}

这样就可以每隔 10 秒执行一次操作。

PeriodicTimer 相比于传统 Timer 的优势在于:

  • PeriodicTimer 将使我们能够异步地等待指定的时间间隔。
  • 在回调的执行过程中,我们可以阻止下一次回调的执行,直到我们完成了当前的操作。

BackgroundService

AspNetCore 中的 BackgroundService 类,它是一个抽象类,实现了 IHostService 接口,可以被用来创建后台服务。使用方法如下:

using?System;
using?System.Threading;
using?System.Threading.Tasks;
using?Microsoft.Extensions.Hosting;

namespace?ConsoleApp1
{
????public?class?DatabaseCheckService?:?BackgroundService
????{
????????protected?override?async?Task?ExecuteAsync(CancellationToken?stoppingToken)
????????{
????????????while?(!stoppingToken.IsCancellationRequested)
????????????{
????????????????Console.WriteLine("Checking?database...");
????????????????//?检查数据库代码
????????????????await?Task.Delay(TimeSpan.FromSeconds(5),?stoppingToken);
????????????}
????????}
????}

????class?Program
????{
????????static?void?Main(string[]?args)
????????{
????????????var?host?=?new?HostBuilder()
????????????????.ConfigureServices((hostContext,?services)?=>
????????????????{
????????????????????services.AddHostedService<DatabaseCheckService>();
????????????????})
????????????????.Build();

????????????host.Run();
????????}
????}
}

在这个例子中,我们继承了 BackgroundService 类并重写了 ExecuteAsync 方法。ExecuteAsync 方法会在后台服务启动时被调用,并在参数 stoppingToken 被取消时退出。我们在 while 循环中使用 Task.Delay 方法来等待 5 秒,并在每次循环中调用检查数据库的代码。

结合使用

我们可以将 PeriodicTimer 和 BackgroundService 结合起来,实现一个定时检查数据库的后台服务。代码如下:

using?System;
using?System.Threading;
using?System.Threading.Tasks;
using?Microsoft.Extensions.Hosting;
using?Microsoft.Extensions.Logging;

namespace?ConsoleApp1
{
????public?class?DatabaseCheckService?:?BackgroundService
????{
????????protected?override?async?Task?ExecuteAsync(CancellationToken?stoppingToken)
????????{
????????????using?var?timer?=?new?PeriodicTimer(TimeSpan.FromSeconds(10));
????????????while?(!stoppingToken.IsCancellationRequested)
????????????{
????????????????if?(await?timer.WaitForNextTickAsync(stoppingToken))
????????????????{
????????????????????Console.WriteLine("Checking?database...");
????????????????????//?检查数据库代码
????????????????}
????????????}
????????}
????}

????class?Program
????{
????????static?void?Main(string[]?args)
????????{
????????????var?host?=?new?HostBuilder()
????????????????.ConfigureServices((hostContext,?services)?=>
????????????????{
????????????????????services.AddHostedService<DatabaseCheckService>();
????????????????})
????????????????.Build();

????????????host.Run();
????????}
????}
}

总结

在这篇文章中,我们介绍了如何使用 .Net 7 中的 PeriodicTimer 类和 BackgroundService 类来实现一个定时检查数据库的后台服务。实际使用中会遇到更多复杂的场景,这篇文章只是一个简单的示例。

到此这篇关于实现.Net7下数据库定时检查的方法详解的文章就介绍到这了,更多相关.Net7数据库定时检查内容请搜索程序员之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持程序员之家!

相关文章

  • ASP.NET实现数据的添加(第10节)

    ASP.NET实现数据的添加(第10节)

    这篇文章主要介绍了ASP.NET如何实现数据的添加,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2015-08-08
  • gridview实现服务器端和客户端全选的两种方法分享

    gridview实现服务器端和客户端全选的两种方法分享

    这篇文章主要介绍了gridview实现服务器端和客户端全选的两种方法,需要的朋友可以参考下
    2014-02-02
  • ASP.NET中IsPostBack用法详解

    ASP.NET中IsPostBack用法详解

    这篇文章主要介绍了ASP.NET中IsPostBack用法,有助于读者进一步理解IsPostBack用法并加以灵活应用,需要的朋友可以参考下
    2014-07-07
  • asp.net 通过aspnetpager为DataList分页

    asp.net 通过aspnetpager为DataList分页

    今天整了半天才把DataList的分页搞定,下面把我的设计过程给大家讲讲
    2009-12-12
  • 10个.NET中删除空白字符串的方法

    10个.NET中删除空白字符串的方法

    我们有无数方法可用于删除字符串中的所有空白。大部分都能够在绝大多数的用例中很好工作,但在某些对时间敏感的应用程序中,是否采用最快的方法可能就会造成天壤之别。
    2015-08-08
  • asp.net通过HttpModule自动在Url地址上添加参数

    asp.net通过HttpModule自动在Url地址上添加参数

    由于项目中有许多页面需要用到cid参数,所以想通过传值cid来获取数据。
    2010-01-01
  • ASP.NETCore6开启文件服务允许通过url访问附件的操作方法

    ASP.NETCore6开启文件服务允许通过url访问附件的操作方法

    最近在做一个工作台的文件上传下载功能,主要想实现上传图片之后,可以通过url直接访问,由于url直接访问文件不安全,所以需要手动开启文件服务,这篇文章主要介绍了ASP.NETCore6开启文件服务允许通过url访问附件,需要的朋友可以参考下
    2023-11-11
  • ASP.NET递归法求阶乘解决思路

    ASP.NET递归法求阶乘解决思路

    递归就是在过程或函数里调用自身,在使用递归策略时,必须有一个明确的递归结束条件,称为递归出口递归算法解题通常显得很简洁,但递归算法解题的运行效率较低。所以一般不提倡用递归算法设计程序
    2012-12-12
  • c#  操作符?? null coalescing operator

    c# 操作符?? null coalescing operator

    ?? "null coalescing" operator 是c#新提供的一个操作符,这个操作符提供的功能是判断左侧的操作数是否是null,如果是则返回结果是右侧的操作数;非null则返回左侧的操作数。
    2009-06-06
  • .Net弹性和瞬态故障处理库Polly介绍

    .Net弹性和瞬态故障处理库Polly介绍

    这篇文章介绍了.Net弹性和瞬态故障处理库Polly,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06

最新评论

?


http://www.vxiaotou.com