2009-08-12 8 views
0

Ich habe eine BizTalk (2006 R2) -Karte, die eine Klasse verwendet, um für einige benutzerdefinierte Logik, die wir nicht ordnungsgemäß durch die vorhandenen Funktoide erreichen konnten.Ausnahmen von der Skripterstellung in BizTalk Map

Wenn eine Ausnahme von einem der Methoden dieser Klasse geworfen wird die Ausnahme Detail ist leider verloren (zumindest soweit ich sehen kann), Die Form verwandelt einfach löst eine Ausnahme angibt 'Function 'ScriptNS-:DoFoo()' has failed'

I‘ Ich komme zu dem Schluss, dass die Verwendung der Scripting-Funktoide in einer Map ein Rezept für eine Katastrophe ist, aber das ist eine andere Diskussion. Meine Frage ist, gibt es einen Mechanismus, um den Ausnahmedetails die Eltern-Orchestrierung zu überlassen?

+0

Ich kann mich nicht an den Kontext für diese Frage erinnern, also weiß ich nicht, ob ich gelöst habe, wie man das Ausnahmedetail erhalten oder nur die spezifische Ausnahme behoben habe. Aber ich dachte mir, ich würde das hinzufügen, wenn es jemand anderem hilft. Ich weiß, dass in BizTalk viele der Exceptions, die von den Orchestrierungskomponenten geworfen werden, als InnerException der tatsächlichen Exception-Nachricht, die Sie erhalten, eingepackt sind. – TygerKrash

Antwort

1

Versuchen Sie, die Klasse 'System.Diagnostics.Trace' zu verwenden, und geben Sie Zeug innerhalb der Methode aus, die sich auf den Fortschritt bezieht. Beginnen Sie mit der Ausgabe der Eingabeparameter, da sie sich von den Erwartungen Ihrer Methode unterscheiden können.

Vereinfachtes Beispiel:

System.Diagnostics.Trace.WriteLine("HelperClass XX - Method YY - This was passed from the map : " + inputParamOne); 

eine klare Benennung Standard macht es einfacher, innerhalb kostenloses Tool Debugview zu filtern, vor allem, wenn auf einer Maschine mehr als Ihre Sachen laufen. Ich hinterlasse diese Spur oft, da sie sich später als unschätzbar erweist. Der Overhead, wenn kein Listener angeschlossen ist, könnte normalerweise ignoriert werden.

Wenn Sie die Karte eingesetzt und läuft auf einer BizTalk Entwicklung Maschine, die Sie, indem Sie die folgenden Schritte debuggen können:

  • einen Haltepunkt in der Methode Put
  • Select ‚Debug - an den Prozess anhängen‘
  • An den HostInstance-Prozess (BTSNTSvc.exe wenn 32-Bit) Behandlung Ihren entsprechenden Port oder Orchestration die Map ausgeführt.