Parcourir la source

refactor.

master
yangxiaodong il y a 7 ans
Parent
révision
1f2716f945
4 fichiers modifiés avec 45 ajouts et 39 suppressions
  1. +3
    -3
      src/DotNetCore.CAP/Internal/DefaultModelBinder.cs
  2. +17
    -30
      src/DotNetCore.CAP/Internal/IConsumerInvoker.Default.cs
  3. +14
    -6
      src/DotNetCore.CAP/Job/IJob.CapJob.cs
  4. +11
    -0
      src/DotNetCore.CAP/LoggerExtensions.cs

+ 3
- 3
src/DotNetCore.CAP/Internal/DefaultModelBinder.cs Voir le fichier

@@ -3,7 +3,7 @@ using System.Linq.Expressions;
using System.Reflection;
using System.Threading.Tasks;
using DotNetCore.CAP.Abstractions.ModelBinding;
using Newtonsoft.Json;
using DotNetCore.CAP.Infrastructure;

namespace DotNetCore.CAP.Internal
{
@@ -17,8 +17,8 @@ namespace DotNetCore.CAP.Internal
{
bindingContext.Model = CreateModel(bindingContext);
}
bindingContext.Result = JsonConvert.DeserializeObject(bindingContext.Values, bindingContext.ModelType);
bindingContext.Result = Helper.FromJson(bindingContext.Values, bindingContext.ModelType);

return Task.CompletedTask;
}


+ 17
- 30
src/DotNetCore.CAP/Internal/IConsumerInvoker.Default.cs Voir le fichier

@@ -11,9 +11,9 @@ namespace DotNetCore.CAP.Internal
{
protected readonly ILogger _logger;
protected readonly IServiceProvider _serviceProvider;
protected readonly ConsumerContext _consumerContext;
private readonly IModelBinder _modelBinder;
private readonly ObjectMethodExecutor _executor;
protected readonly ConsumerContext _consumerContext;

public DefaultConsumerInvoker(ILogger logger,
IServiceProvider serviceProvider,
@@ -30,42 +30,29 @@ namespace DotNetCore.CAP.Internal

public Task InvokeAsync()
{
try
using (_logger.BeginScope("consumer invoker begin"))
{
using (_logger.BeginScope("consumer invoker begin"))
{
_logger.LogDebug("Executing consumer Topic: {0}", _consumerContext.ConsumerDescriptor.Attribute);
_logger.LogDebug("Executing consumer Topic: {0}", _consumerContext.ConsumerDescriptor.MethodInfo.Name);

try
{
var obj = ActivatorUtilities.GetServiceOrCreateInstance(_serviceProvider, _consumerContext.ConsumerDescriptor.ImplTypeInfo.AsType());
var obj = ActivatorUtilities.GetServiceOrCreateInstance(_serviceProvider, _consumerContext.ConsumerDescriptor.ImplTypeInfo.AsType());

var value = _consumerContext.DeliverMessage.Content;
var value = _consumerContext.DeliverMessage.Content;

if (_executor.MethodParameters.Length > 0)
{
var firstParameter = _executor.MethodParameters[0];
if (_executor.MethodParameters.Length > 0)
{
var firstParameter = _executor.MethodParameters[0];

var bindingContext = ModelBindingContext.CreateBindingContext(value,
firstParameter.Name, firstParameter.ParameterType);
var bindingContext = ModelBindingContext.CreateBindingContext(value,
firstParameter.Name, firstParameter.ParameterType);

_modelBinder.BindModelAsync(bindingContext);
_executor.Execute(obj, bindingContext.Result);
}
else
{
_executor.Execute(obj);
}
return Task.CompletedTask;
}
finally
{
_logger.LogDebug("Executed consumer method .");
}
_modelBinder.BindModelAsync(bindingContext);
_executor.Execute(obj, bindingContext.Result);
}
}
finally
{
else
{
_executor.Execute(obj);
}
return Task.CompletedTask;
}
}
}

+ 14
- 6
src/DotNetCore.CAP/Job/IJob.CapJob.cs Voir le fichier

@@ -41,15 +41,23 @@ namespace DotNetCore.CAP.Job
var nextReceivedMessage = await messageStore.GetNextReceivedMessageToBeExcuted();
if (nextReceivedMessage != null)
{
var executeDescriptor = matchs[nextReceivedMessage.KeyName];
var consumerContext = new ConsumerContext(executeDescriptor, nextReceivedMessage);
var invoker = _consumerInvokerFactory.CreateInvoker(consumerContext);
try
{
var executeDescriptor = matchs[nextReceivedMessage.KeyName];
var consumerContext = new ConsumerContext(executeDescriptor, nextReceivedMessage);
var invoker = _consumerInvokerFactory.CreateInvoker(consumerContext);

await messageStore.ChangeReceivedMessageStateAsync(nextReceivedMessage, StatusName.Processing);
await messageStore.ChangeReceivedMessageStateAsync(nextReceivedMessage, StatusName.Processing);

await invoker.InvokeAsync();
await invoker.InvokeAsync();

await messageStore.ChangeReceivedMessageStateAsync(nextReceivedMessage, StatusName.Succeeded);
}
catch (Exception ex)
{
_logger.ReceivedMessageRetryExecutingFailed(nextReceivedMessage.KeyName, ex);
}

await messageStore.ChangeReceivedMessageStateAsync(nextReceivedMessage,StatusName.Succeeded);
}
}
}


+ 11
- 0
src/DotNetCore.CAP/LoggerExtensions.cs Voir le fichier

@@ -21,6 +21,7 @@ namespace DotNetCore.CAP
private static Action<ILogger, string, string, Exception> _enqueuingSentMessage;
private static Action<ILogger, string, string, Exception> _enqueuingReceivdeMessage;
private static Action<ILogger, string, Exception> _executingConsumerMethod;
private static Action<ILogger, string, Exception> _receivedMessageRetryExecuting;

static LoggerExtensions()
{
@@ -78,6 +79,11 @@ namespace DotNetCore.CAP
LogLevel.Error,
5,
"Consumer method '{methodName}' failed to execute.");

_receivedMessageRetryExecuting = LoggerMessage.Define<string>(
LogLevel.Error,
5,
"Received message topic method '{topicName}' failed to execute.");
}

public static void ConsumerMethodExecutingFailed(this ILogger logger, string methodName, Exception ex)
@@ -85,6 +91,11 @@ namespace DotNetCore.CAP
_executingConsumerMethod(logger, methodName, ex);
}

public static void ReceivedMessageRetryExecutingFailed(this ILogger logger, string topicName, Exception ex)
{
_receivedMessageRetryExecuting(logger, topicName, ex);
}

public static void EnqueuingReceivedMessage(this ILogger logger, string nameKey, string content)
{
_enqueuingReceivdeMessage(logger, nameKey, content, null);


Chargement…
Annuler
Enregistrer