Skip to content
  • P
    Projects
  • G
    Groups
  • S
    Snippets
  • Help

丁松杰 / Pole

  • This project
    • Loading...
  • Sign in
Go to a project
  • Project
  • Repository
  • Issues 0
  • Merge Requests 0
  • Pipelines
  • Wiki
  • Snippets
  • Members
  • Activity
  • Graph
  • Charts
  • Create a new issue
  • Jobs
  • Commits
  • Issue Boards
  • Files
  • Commits
  • Branches
  • Tags
  • Contributors
  • Graph
  • Compare
  • Charts
Switch branch/tag
  • Pole
  • src
  • Pole.Sagas.Server
  • Processor
  • ExpiredSagasCollectorProcessor.cs
Find file
BlameHistoryPermalink
  • dingsongjie's avatar
    完成 90% · 7ef7a1a7
    dingsongjie committed 5 years ago
    7ef7a1a7
ExpiredSagasCollectorProcessor.cs 2.4 KB
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
using Pole.Core.Processor;
using Pole.Sagas.Core;
using Pole.Sagas.Core.Abstraction;
using System;
using System.Collections.Generic;
using System.Text;
using System.Threading.Tasks;

namespace Pole.Sagas.Server.Processor
{
    class ExpiredSagasCollectorProcessor : ProcessorBase
    {
        private readonly ISagaStorage sagaStorage;
        private readonly PoleSagasServerOption options;
        private readonly ILogger logger;
        private readonly ISagaStorageInitializer sagaStorageInitializer;
        public ExpiredSagasCollectorProcessor(ISagaStorage sagaStorage, IOptions<PoleSagasServerOption> options, ILogger<ExpiredSagasCollectorProcessor> logger, ISagaStorageInitializer sagaStorageInitializer)
        {
            this.sagaStorage = sagaStorage;
            this.options = options.Value ?? throw new Exception($"{nameof(PoleSagasServerOption)} Must be injected");
            this.logger = logger;
            this.sagaStorageInitializer = sagaStorageInitializer;
        }
        public override string Name => nameof(NotEndedSagasFetchProcessor);


        public override async Task Process(ProcessingContext context)
        {
            try
            {
                await ProcessInternal();
            }
            catch (Exception ex)
            {
                logger.LogError(ex, $"{nameof(NotEndedSagasFetchProcessor)} Process Error");
            }
            finally
            {
                await Task.Delay(options.ExpiredDataBulkDeleteIntervalSeconds * 1000);
            }
        }

        private async Task ProcessInternal()
        {
            var tables = new[] { sagaStorageInitializer.GetSagaTableName() };

            foreach (var table in tables)
            {
                logger.LogDebug($"Collecting expired data from table: {table}");

                int deletedCount;
                var time = DateTime.UtcNow;
                do
                {
                    deletedCount = await sagaStorage.DeleteExpiredData(table, time, options.ExpiredDataDeleteBatchCount);

                    if (deletedCount == options.ExpiredDataDeleteBatchCount)
                    {
                        await Task.Delay(options.ExpiredDataPreBulkDeleteDelaySeconds * 1000);
                    }
                } while (deletedCount == options.ExpiredDataDeleteBatchCount);
            }
        }
    }
}