Files
Yi.Framework/Yi.Framework.Net5/Yi.Framework.StaticPageProcessor/WarmupPageWorker.cs
2021-12-25 14:50:54 +08:00

134 lines
5.6 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Yi.Framework.Common.IOCOptions;
using Yi.Framework.Common.Models;
using Yi.Framework.Common.QueueModel;
using Yi.Framework.Core;
using Yi.Framework.Core.ConsulExtend;
namespace Yi.Framework.StaticPageProcessor
{
public class WarmupPageWorker : BackgroundService
{
private readonly IConfiguration _configuration;
private readonly ILogger<WarmupPageWorker> _logger;
private readonly RabbitMQInvoker _RabbitMQInvoker;
private readonly AbstractConsulDispatcher _IConsulDispatcher = null;
public WarmupPageWorker(ILogger<WarmupPageWorker> logger, RabbitMQInvoker rabbitMQInvoker, IConfiguration configuration, AbstractConsulDispatcher consulDispatcher)
{
this._logger = logger;
this._RabbitMQInvoker = rabbitMQInvoker;
this._configuration = configuration;
this._IConsulDispatcher = consulDispatcher;
}
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
RabbitMQConsumerModel rabbitMQConsumerModel = new RabbitMQConsumerModel()
{
ExchangeName = RabbitMQExchangeQueueName.SKUWarmup_Exchange,
QueueName = RabbitMQExchangeQueueName.SKUWarmup_Queue_StaticPage
};
HttpClient _HttpClient = new HttpClient();
this._RabbitMQInvoker.RegistReciveAction(rabbitMQConsumerModel, message =>
{
string realUrl= this._IConsulDispatcher.GetAddress(this._configuration["DetailPageUrl"]);
SKUWarmupQueueModel skuWarmupQueueModel = JsonConvert.DeserializeObject<SKUWarmupQueueModel>(message);
#region ÏÈClearAll
{
string totalUrl = $"{realUrl}{0}.html?ActionHeader=ClearAll";
try
{
var result = _HttpClient.GetAsync(totalUrl).Result;
if (result.StatusCode == HttpStatusCode.OK)
{
this._logger.LogInformation($"{nameof(WarmupPageWorker)}.ClearAll succeed {totalUrl}");
//return true;
}
else
{
this._logger.LogWarning($"{nameof(WarmupPageWorker)}.ClearAll failed {totalUrl}");
return false;
}
}
catch (Exception ex)
{
this._logger.LogError($"{nameof(WarmupPageWorker)}.ClearAll failed {totalUrl}, Exception:{ex.Message}");
return false;
}
}
#endregion
#region È»ºóÈ«²¿´´½¨ Warmup
{
//ÏÞÁ÷£¿ °×Ãûµ¥----·ÖÅú---¼Ç¼µ±ÏµÈ
int count = 100;//µ¥´Î²éѯ
int pageIndex = 1;//·ÖÒ³µÄÒ³ÂëÆßµã
while (count == 100)
{
// -------------------> ´Ë´¦Éú³É¾²Ì¬Ò³Ãû³Æ£¬Í¨³£Ê¹ÓÃid±êʶ,¿ÉÒÔͨ¹ýµ÷ÓÃserviceµÄ²éѯ·½·¨µÃµ½ËùÓÐid
List<long> ids = new List<long>{ 1,2,3,4,5,6,7,8,9};
// -------------------> ´Ë´¦Éú³É¾²Ì¬Ò³Ãû³Æ£¬Í¨³£Ê¹ÓÃid±êʶ,¿ÉÒÔͨ¹ýµ÷ÓÃserviceµÄ²éѯ·½·¨µÃµ½ËùÓÐid
foreach (var id in ids)
{
string totalUrl = $"{realUrl}{id}.html";
try
{
var result = _HttpClient.GetAsync(totalUrl).Result;
if (result.StatusCode == HttpStatusCode.OK)
{
this._logger.LogInformation($"{nameof(WarmupPageWorker)}.Warmup succeed {totalUrl}");
//return true;
}
else
{
this._logger.LogWarning($"{nameof(WarmupPageWorker)}.Warmup failed {totalUrl}");
return false;
}
}
catch (Exception ex)
{
var logModel = new LogModel()
{
OriginalClassName = this.GetType().FullName,
OriginalMethodName = nameof(ExecuteAsync),
Remark = "¶¨Ê±×÷Òµ´íÎóÈÕÖ¾"
};
this._logger.LogError(ex, $"{nameof(WarmupPageWorker)}.Warmup failed {totalUrl}, Exception:{ex.Message}", JsonConvert.SerializeObject(logModel));
return false;
}
}
pageIndex++;
count = ids.Count;
}
}
#endregion
return true;
});
await Task.CompletedTask;
//while (!stoppingToken.IsCancellationRequested)
//{
// _logger.LogInformation("Worker running at: {time}", DateTimeOffset.Now);
// await Task.Delay(1000, stoppingToken);
//}
}
}
}