private T Retry <T>(Func <T> retryme) => RetryHelper.Retry(retryme, _managerConfiguration.RetryTimeout, _managerConfiguration.MaxRetries, Logger);
private T Retry <T>(Func <T> retryme) => RetryHelper.Retry(retryme, this.Manager.Configuration.RetryTimeout, this.Manager.Configuration.MaxRetries);
/// <summary> /// Initializes a new instance of the <see cref="RedisCacheBackPlate"/> class. /// </summary> /// <param name="configuration">The cache manager configuration.</param> /// <param name="loggerFactory">The logger factory</param> public RedisCacheBackPlate(CacheManagerConfiguration configuration, ILoggerFactory loggerFactory) : base(configuration) { NotNull(configuration, nameof(configuration)); NotNull(loggerFactory, nameof(loggerFactory)); this.logger = loggerFactory.CreateLogger(this); this.channelName = configuration.BackPlateChannelName ?? "CacheManagerBackPlate"; this.identifier = Guid.NewGuid().ToString(); var cfg = RedisConfigurations.GetConfiguration(this.ConfigurationKey); this.connection = new RedisConnectionManager( cfg, loggerFactory); RetryHelper.Retry(() => this.Subscribe(), configuration.RetryTimeout, configuration.MaxRetries, logger); this.timer = new Timer( (obj) => { if (this.sending) { return; } lock (this.messageLock) { try { this.sending = true; if (this.messages != null && this.messages.Count > 0) { var msgs = string.Join(",", this.messages); if (this.logger.IsEnabled(LogLevel.Debug)) { this.logger.LogDebug("Back-plate is sending {0} messages ({1} skipped).", this.messages.Count, this.skippedMessages); } RetryHelper.Retry( () => { this.Publish(msgs); }, configuration.RetryTimeout, configuration.MaxRetries, this.logger); this.skippedMessages = 0; this.messages.Clear(); } } catch (Exception ex) { this.logger.LogError(ex, "Error occurred sending back plate messages."); } finally { this.sending = false; } } }, this, TimeSpan.FromMilliseconds(100), TimeSpan.FromMilliseconds(100)); }