MES-ETL/ConsoleApp2/HostedServices/TransformService.cs

81 lines
3.1 KiB
C#
Raw Normal View History

2024-01-04 09:00:44 +08:00
using ConsoleApp2.Const;
using ConsoleApp2.HostedServices.Abstractions;
2023-12-29 16:16:05 +08:00
using ConsoleApp2.Options;
using ConsoleApp2.Services;
using Microsoft.Extensions.Caching.Distributed;
2023-12-29 16:16:05 +08:00
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
2024-01-16 18:00:23 +08:00
using StackExchange.Redis;
2023-12-29 16:16:05 +08:00
namespace ConsoleApp2.HostedServices;
2024-01-04 09:00:44 +08:00
/// <summary>
/// 数据处理服务,对导入后的数据进行处理
/// </summary>
public class TransformService : ITransformService
2023-12-29 16:16:05 +08:00
{
private readonly ILogger _logger;
private readonly IOptions<DataTransformOptions> _options;
private readonly ProcessContext _context;
private readonly IDistributedCache _cache;
2024-01-18 14:36:36 +08:00
private readonly TaskManager _taskManager;
2023-12-29 16:16:05 +08:00
2024-01-04 09:00:44 +08:00
public TransformService(ILogger<TransformService> logger,
IOptions<DataTransformOptions> options,
ProcessContext context,
2024-01-18 14:36:36 +08:00
IDistributedCache cache,
TaskManager taskManager)
2023-12-29 16:16:05 +08:00
{
_logger = logger;
_options = options;
_context = context;
_cache = cache;
2024-01-18 14:36:36 +08:00
_taskManager = taskManager;
2023-12-29 16:16:05 +08:00
}
2024-01-18 14:36:36 +08:00
public async Task ExecuteAsync(TasksOptions tasksOptions, DataRecordQueue producerQueue, DataRecordQueue consumerQueue, ProcessContext context, CancellationToken cancellationToken)
2023-12-29 16:16:05 +08:00
{
_logger.LogInformation("***** Data transform service started, thread id: {ThreadId} *****", Environment.CurrentManagedThreadId);
2024-01-18 14:36:36 +08:00
_taskManager.CreateTasks(async () =>
2023-12-29 16:16:05 +08:00
{
2024-01-18 14:36:36 +08:00
while ((!context.IsInputCompleted || producerQueue.Count > 0))
2024-01-12 16:50:37 +08:00
{
2024-01-18 14:36:36 +08:00
if (!producerQueue.TryDequeue(out var record)) continue;
2023-12-29 16:16:05 +08:00
2024-01-18 14:36:36 +08:00
//过滤不要的record
if (await _options.Value.RecordFilter?.Invoke(record, _cache) == false) continue;
//修改record
_options.Value.RecordModify?.Invoke(record);
//缓存record
await _options.Value.RecordCache?.Invoke(record, _cache);
2024-01-18 14:36:36 +08:00
//替换record
var replaceRecord = await _options.Value.RecordReplace?.Invoke(record, _cache);
if (replaceRecord != null)
{
record = replaceRecord;
}
//计算需要分流的数据库
record.Database = _options.Value.DatabaseFilter.Invoke(record);
2024-01-18 14:36:36 +08:00
consumerQueue.Enqueue(record);
_context.AddTransform();
//数据增加
var addRecords = _options.Value.RecordAdd?.Invoke(record);
if (addRecords is { Count: > 0 })
2024-01-18 14:36:36 +08:00
{
foreach (var rc in addRecords)
{
rc.Database = _options.Value.DatabaseFilter.Invoke(record);
2024-01-18 14:36:36 +08:00
consumerQueue.Enqueue(rc);
_context.AddTransform();
}
}
}
context.CompleteTransform();
},tasksOptions.TransformTaskCount,cancellationToken);
await _taskManager.WaitAll();
2023-12-29 16:16:05 +08:00
_logger.LogInformation("***** Data transformation service completed *****");
}
}