2016-09-14 1 views
1

Для лазурных агентских услуг, метод актера. Запустите «Остановить журналы» в окне «Диагностика», как показано ниже.Метод актера Пуск/Стоп лог | Добавить дополнительную информацию

Как добавить дополнительную информацию, такую ​​как Идентификатор корреляции, каждый раз, когда вызывается метод?

{ 
    "Timestamp": "2016-09-14T19:46:40.9955448+05:30", 
    "ProviderName": "Microsoft-ServiceFabric-Actors", 
    "Id": 7, 
    "Message": "Actor method is being invoked. Method name: IStore.GetStoreById, actor type: Backend.Actor.Store.Store, actor ID: STORE_6.", 
    "ProcessId": 30736, 
    "Level": "Verbose", 
    "Keywords": "0x0000F00000000002", 
    "EventName": "ActorMethod/Start", 
    "Payload": { 
    "methodName": "IStore.GetStoreById", 
    "methodSignature": "System.Threading.Tasks.Task`1[Backend.Models.Store.StoreView] GetStoreById(System.String)", 
    "actorType": "Backend.Actor.Store.Store", 
    "actorId": "STORE_6", 
    "actorIdKind": 2, 
    "replicaOrInstanceId": 131183360004211655, 
    "partitionId": "8af1c125-3666-40d0-b630-e3570c41833b", 
    "serviceName": "fabric:/MultiBannerBackend/StoreActorService", 
    "applicationName": "fabric:/MultiBannerBackend", 
    "serviceTypeName": "StoreActorServiceType", 
    "applicationTypeName": "MultiBannerBackendType", 
    "nodeName": "_Node_4" 
    } 
} 

ответ

0

Для того, чтобы войти пользовательские данные для каждой операции Actor, вы можете использовать эти методы:

protected override Task OnPreActorMethodAsync(ActorMethodContext c) 
protected override Task OnPostActorMethodAsync(ActorMethodContext c) 

Для того, чтобы получить контекст вызова, я обнаружил, что CallContext.LogicalGetData не работать в этой ситуации. К счастью, сам актер знает о своем контексте. Вы можете получить это, используя некоторое отражение.

Например:

protected override Task OnPreActorMethodAsync(ActorMethodContext c) 
     { 
      var correlationID = this.GetActorContext() ?? Guid.Empty.ToString("N"); 
      string message = $"Actor method is being invoked. Method name: {c.MethodName}, actor type: {GetType().FullName}, actor ID: {Id}, CorrelationID:{correlationID}"; 
      ActorEventSource.Current.ActorMessage(this, message); 
      return Task.FromResult(true); 
     } 

     protected override Task OnPostActorMethodAsync(ActorMethodContext c) 
     { 
      var correlationID = this.GetActorContext() ?? Guid.Empty.ToString("N"); 
      string message = $"Actor method has completed. Method name: {c.MethodName}, actor type: {GetType().FullName}, actor ID: {Id}, CorrelationID:{correlationID}"; 
      ActorEventSource.Current.ActorMessage(this, message); 
      return Task.FromResult(true); 
     } 

В сочетании с:

public static class ActorContextExtensions 
    { 
     public static string GetActorContext(this Actor actor) 
     { 
      var concurrencyLockProperty = GetPropertyInfo("ConcurrencyLock", typeof(ActorBase)); 
      var concurrencyLockPropertyValue = concurrencyLockProperty.GetValue(actor); 

      var currentContextProperty = GetPropertyInfo("Test_CurrentContext", concurrencyLockPropertyValue.GetType()); 
      string currentContextPropertyValue = (string)currentContextProperty.GetValue(concurrencyLockPropertyValue); 
      return currentContextPropertyValue; 
     } 

     private static PropertyInfo GetPropertyInfo(string propertyName, IReflect owner) 
     { 
      var property = owner.GetProperty(propertyName, BindingFlags.NonPublic | BindingFlags.Instance); 
      if (property == null) throw new InvalidOperationException($"Failed to find property '{propertyName}' on '{owner}'."); 
      return property; 
     } 
    } 

Очевидным недостатком этого является всякий раз, когда внутренние изменения ActorBase, вам необходимо изменить код отражения соответственно.

+0

Большое спасибо, это именно то, что я искал. – user1800524