Blog.Core/Blog.Core.Extensions/HostedService/Job1TimedService.cs

61 lines
1.6 KiB
C#
Raw Normal View History

2022-02-23 18:14:26 +08:00
using Blog.Core.Common;
2019-06-19 18:56:16 +08:00
using Blog.Core.IServices;
using Microsoft.Extensions.Hosting;
using System;
using System.Threading;
using System.Threading.Tasks;
2023-02-05 22:36:15 +08:00
namespace Blog.Core.Extensions
2019-06-19 18:56:16 +08:00
{
public class Job1TimedService : IHostedService, IDisposable
{
private Timer _timer;
private readonly IBlogArticleServices _blogArticleServices;
// 这里可以注入
public Job1TimedService(IBlogArticleServices blogArticleServices)
{
_blogArticleServices = blogArticleServices;
}
public Task StartAsync(CancellationToken cancellationToken)
{
Console.WriteLine("Job 1 is starting.");
_timer = new Timer(DoWork, null, TimeSpan.Zero,
2020-04-30 18:17:27 +08:00
TimeSpan.FromSeconds(60 * 60));//一个小时
2019-06-19 18:56:16 +08:00
return Task.CompletedTask;
}
2020-09-03 21:38:39 +08:00
private void DoWork(object state)
2019-06-19 18:56:16 +08:00
{
try
{
2020-09-03 21:38:39 +08:00
var model = _blogArticleServices.GetBlogDetails(1).Result;
2020-04-30 18:17:27 +08:00
Console.WriteLine($"Job 1 启动成功获取id=1的博客title为:{model?.btitle}");
}
catch (Exception ex)
{
Console.WriteLine($"Error:{ex.Message}");
}
2019-06-19 18:56:16 +08:00
ConsoleHelper.WriteSuccessLine($"Job 1 {DateTime.Now}");
}
public Task StopAsync(CancellationToken cancellationToken)
{
Console.WriteLine("Job 1 is stopping.");
_timer?.Change(Timeout.Infinite, 0);
return Task.CompletedTask;
}
public void Dispose()
{
_timer?.Dispose();
}
}
}