整理代码
This commit is contained in:
		| @@ -21,7 +21,7 @@ public class TransformService : ITransformService | ||||
|     private readonly IDistributedCache _cache; | ||||
|  | ||||
|  | ||||
|     public TransformService(ILogger<TransformService> logger,  | ||||
|     public TransformService(ILogger<TransformService> logger, | ||||
|         IOptions<DataTransformOptions> options, | ||||
|         ProcessContext context, | ||||
|         IDistributedCache cache) | ||||
| @@ -35,30 +35,41 @@ public class TransformService : ITransformService | ||||
|     public async Task ExecuteAsync(TasksOptions tasksOptions, DataRecordQueue producerQueue, DataRecordQueue consumerQueue, ProcessContext context, CancellationToken cancellationToken) | ||||
|     { | ||||
|         _logger.LogInformation("***** Data transform service started, thread id: {ThreadId} *****", Environment.CurrentManagedThreadId); | ||||
|             while ((!context.IsInputCompleted || producerQueue.Count > 0)) | ||||
|         while ((!context.IsInputCompleted || producerQueue.Count > 0)) | ||||
|         { | ||||
|             if (_context.GetExceptions().Count > 0) | ||||
|             { | ||||
|                 if (_context.GetExceptions().Count > 0) | ||||
|                 { | ||||
|                     _logger.LogInformation("***** Csv transform service is canceled *****"); | ||||
|                     return; | ||||
|                 } | ||||
|                 if (!producerQueue.TryDequeue(out var record)) continue; | ||||
|                 _logger.LogInformation("***** Csv transform service is canceled *****"); | ||||
|                 return; | ||||
|             } | ||||
|             if (!producerQueue.TryDequeue(out var record)) continue; | ||||
|  | ||||
|                 //过滤不要的record | ||||
|                 if (await _options.Value.RecordFilter?.Invoke(record, _cache) == false) continue; | ||||
|                 record.Database = _options.Value.DatabaseFilter?.Invoke(record); | ||||
|                 //修改record | ||||
|                 _options.Value.RecordModify?.Invoke(record); | ||||
|                 //缓存record | ||||
|                 await _options.Value.RecordCache?.Invoke(record, _cache); | ||||
|                 //替换record | ||||
|                 var replaceRecord = await _options.Value.RecordReplace?.Invoke(record, _cache); | ||||
|                 if (replaceRecord != null) | ||||
|             //过滤不要的record | ||||
|  | ||||
|             if (_options.Value.RecordFilter != null) | ||||
|             { | ||||
|                 var result = await _options.Value.RecordFilter.Invoke(record, _cache); | ||||
|                 if (result == false) continue; | ||||
|             } | ||||
|             record.Database = _options.Value.DatabaseFilter?.Invoke(record); | ||||
|             //修改record | ||||
|             _options.Value.RecordModify?.Invoke(record); | ||||
|             //缓存record | ||||
|             if (_options.Value.RecordCache != null) | ||||
|             { | ||||
|                 await _options.Value.RecordCache.Invoke(record, _cache); | ||||
|             } | ||||
|             //替换record | ||||
|             if (_options.Value.RecordReplace != null) | ||||
|             { | ||||
|                 var result = await _options.Value.RecordReplace.Invoke(record, _cache); | ||||
|                 if (result != null) | ||||
|                 { | ||||
|                     record = replaceRecord; | ||||
|                     record = result; | ||||
|                 } | ||||
|                 consumerQueue.Enqueue(record); | ||||
|                 _context.AddTransform(); | ||||
|             } | ||||
|             consumerQueue.Enqueue(record); | ||||
|             _context.AddTransform(); | ||||
|             //数据增加 | ||||
|             var addRecords = _options.Value.RecordAdd?.Invoke(record); | ||||
|             if (addRecords != null && addRecords.Count > 0) | ||||
| @@ -70,8 +81,8 @@ public class TransformService : ITransformService | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|             context.CompleteTransform(); | ||||
|      | ||||
|         context.CompleteTransform(); | ||||
|  | ||||
|         _logger.LogInformation("***** Data transformation service completed *****"); | ||||
|     } | ||||
| } | ||||
| @@ -445,7 +445,7 @@ async Task RunProgram() | ||||
|  | ||||
|     host.Services.AddHostedService<MainHostedService>(); | ||||
|     host.Services.AddHostedService<TaskMonitorService>(); | ||||
|     if(commandOptions.IsMock)host.Services.AddSingleton<IInputService,SimulationInputService>(); | ||||
|     if(commandOptions.IsMock)host.Services.AddSingleton<IInputService,InputService>(); | ||||
|     else host.Services.AddSingleton<IInputService, InputService>(); | ||||
|     host.Services.AddSingleton<ITransformService, TransformService>(); | ||||
|     host.Services.AddSingleton<IOutputService, OutputService>(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user