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
|
|
|
|
{
|
2019-12-18 17:52:38 +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}");
|
2019-12-18 17:52:38 +08:00
|
|
|
|
}
|
2020-04-03 15:33:29 +08:00
|
|
|
|
catch (Exception ex)
|
2019-12-18 17:52:38 +08:00
|
|
|
|
{
|
2020-04-03 15:33:29 +08:00
|
|
|
|
Console.WriteLine($"Error:{ex.Message}");
|
2019-12-18 17:52:38 +08:00
|
|
|
|
}
|
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();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|