poniedziałek, 6 lutego 2023

IIS Tracing - czyli jak debugować problemy, które nie zostawiają śladów w logach

 Pracując z produkcyjnymi aplikacji hostowanymi na IISie możemy napotkać na trudności z błędami typu 500. Błędy te są trudne w debugowaniu, zwłaszcza, gdy pojawiają się sporadycznie a w aplikacji nie ma wystarczającego logowania, które przechwytuje wszystkie wyjątki. 

Pomóc w takim przypadku może opcja Tracingu dostępna w serwerze IIS. Na początek należy sprawdzić czy potrzebne funkcje są zainstalowane:


Po instalacji Tracingu w IIS - przystępujemy do konfiguracji. Aktywować Tracing możemy zarówno poprzez klikanie w UI IISa, jak i dużo łatwiej i szybciej za pomocą PowerShella (to rozwiązane także łatwo zautomatyzować w przypadku dużej ilości serwerów). 

1 Sposób - UI IIS Console

Pierwszy sposób polega na wyklikaniu wszystkiego w interfejsie graficznym. Konfigurację możemy dokonać na poziomie Serwera lub konkretnej aplikacji. Jeżeli dokonamy konfiguracji na poziomie Serwera, wszystkie strony będą niejako dziedziczyły ją. Zaczniemy od zdefiniowania kryteriów logowania, następnie włączymy Tracking i ustawimy gdzie i ile plików ma zostać zapisane. 



W nowym okienku klikamy po prawej stronie w manu Actions -> Add... Otworzy się kreator, w którym możemy dokonać wyboru opcji. W pierwszym kroku możemy wybrać co chcemy logować:

W kolejnym kroku wybieramy warunki logowania (np. wszystkie wiadomości które zakończyły się błędem 500):

Ostatni krok pozwala wybrać poziom prowidera i poziom logowania:

Polecam na początek ustawić logowanie na wszystko na poziome Verbose. Pliki logów nie zajmują dużo a więcej detali ułatwi szukanie odpowiedzi dlaczego aplikacja nie działa poprawnie.

Ostatnim krokiem jest właściwie włączenie Tracingu na Site. Podobnie jak poprzednio wykorzystamy UI IISa:
Po lewej strony z menu wybieramy interesujący nas Site. Następnie po prawej stronie Configuration -> Failed Request Tracking...

W nowym okienku wybieramy:
  • zaznaczamy Enable aby włączyć logowanie
  • Directory - miejsce gdzie zostaną zapisane logi
  • Maximum number of trace files - 50 logów wydaje się nie dużą ilością, polecam ustawić co najmniej 1000 logów

Po zaakceptowaniu ustawień, wszystko jest gotowe i możemy czekać na pierwsze logi. 

2 Sposób - PowerShell

Moim zdaniem dużo prostszy i łatwiejszy sposób konfiguracji. Zacznijmy od komendy która dodaje Tracing na błędy z kodem 500 (czyli de fakto to co poprzednio wyklikiwaliśmy ręcznie):
Enable-WebRequestTracing -StatusCodes 500 -MaxLogFiles 2000

Jeżeli chcemy wskazać dokładnie jeden Site do tracowania wystarczy dodać parametr -Name "Site Name"

Do wyłączenia tracingu służy komenda:

Disable-WebRequestTracing

Tak samo możemy wyspecyfikować Site na którym chcemy wyłączyć tracing za pomocą parametru -Name. Wyłączenie tracingu nie powoduje usunięcia jego ustawień. Aby wyczyścić wszystkie ustawienia, należy skorzystać z komendy:

Clear-WebRequestTracingSettings


Przeglądanie plików Traca

Pliki traców zapisywane są jako pliki typu XML wraz z jednym plikiem transformacji XSL.

Otworzyć je możemy tylko po uprzednim zahostowaniu ich na serwerze WWW. Jeżeli spróbujemy otworzyć plik bezpośrednio w przeglądarce zobaczymy błąd bezpieczeństwa. 

Ja użyłem IISa aby zahostować plik i to wynik po nałożeniu formatowania:

Logi traca dostarczają wielu przydatnych informacji, jak:
  • zdarzenia dla każdego modułu, który brał udział przy procesowaniu requestu
  • który moduł zawiódł
  • hedery z requesta
  • body requesta
  • response wychodzący do klienta

W przypadku powyżej po anallizie, okazało się, że request zawierał niedozwolone znaki dla XMLa. Bez możliwości szybkiego wrzucenia nowej wersji kodu z odpowiednim logowaniem, trace wydaje się idealnym narzędziem pozwalającym zidentyfikować problem. 

Brak komentarzy:

Prześlij komentarz