|
Trace mesajlarının veritabanına yönlendirilmesi - DBTraceListener |
|
Gönderiliyor lütfen bekleyin... |
|
|
Tracing, uygulamamızı çalışma zamanında takip etme işlemidir. Geliştirdiğimiz uygulamada hata oluştuğunda, hata nedenini bulabilmek için kullandığımız vazgeçilmez yöntemdir.
ASP.NET’te trace kullanımı hakkında daha detaylı bilgi için tıklayın.
TraceListener sınıfları uygulama içerisinde trace’e yazılan mesajları dinleyen ve bir vari kaynağına yönlendiren sınıflardır.
System.Diagnostics namespace’i altındaki EventLogTraceListener, TextWriterTraceListener sınıfları TraceListener sınıfından türemiş özelleşmiş trace dinleyicileridir.
Aynı şekilde TraceListener sınıfından türeterek yazdığım DBTraceListener sınıfı, trace mesajlarını veritabanına yazar. Performans açısından uygulamayı yavaşlatmaması için veritabanı işlemlerini asenkron yapar.
Kurulum ve Ayarlar
1. Veritabanı kurulumu "DBScripts.sql" ile yapılır.
2. DBTraceListener kullanılacak projenin "\bin" klasörüne "CustomTraceListeners.dll" DLL’i kopyalanır.
3. DBTraceListener kullanılacak projenin config dosyasına (Web projeleri için "Web.config", windows uygulamaları için "App.config")
aşağıdaki ayarlar düzenlenerek eklenir.
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<appSettings>
<add key="connectionString" value="Server=MORDOR;Database=ApplicationTraceDB;user=TraceUser;pwd=TrAcEuSeR" />
</appSettings>
<system.diagnostics>
<switches>
<add name="DBTraceListenerEnabled" value="1" />
</switches>
<trace autoflush="true" indentsize="2">
<listeners>
<remove name="Default"/>
<add name="DBTraceListener"
type="CustomTraceListeners.DBTraceListener, CustomTraceListeners"
/>
</listeners>
</trace>
</system.diagnostics>
</configuration>
|
Yukarıdaki kurulumu yaptıktan sonra projenizi derlerken proje özelliklerinde, derleme değişkenlerine TRACE’i eklerseniz, uygulamanız içerisinde trace’e yazdığınız herşey DBTraceListener tarafından kurulumunu yaptığınız veritabanına yazılacaktır.
Şekil 1. Proje Özellikleri - Derleme değişkenleri
DBTraceListener’i uygulamanızdan çıkarmak için :
1. Kurulum sırasında eklediğiniz "CustomTraceListeners.dll" DLL’ini "\bin" klasöründen çıkarmanız.
2. Projenin config dosyasından (Web projeleri için "Web.config", windows uygulamaları için "App.config"), kurulum için eklediğiniz ayarları silmeniz yeterli.
Yalnız dikkat etmeniz gereken bir husus : bu durumda uygulamanız hala trace’e yazıyor olacak ve bu bir ölçüde performans kaybına sebep olacaktır. Projenizi derlerken, derleme değişkenlerinden TRACE’i kaldırmanız yeterli olacaktır.
Kullanım
Uygulamanız içerisinde herhangi bir yerde aşağıdaki gibi Trace’e yazmanız yeterlidir :
(Not : Config dosyasına eklediğiniz DBTraceListenerEnabled değerinin 1 olması durumunda BooleanSwitch kullanan 3. örnek çalışacaktır. Trace’i kapatıp açmak için bu ayarı kullanabilirsiniz. )
// Örnek Kullanım 1 :
System.Diagnostics.Trace.Write("Kategori kullanmadan trace’e yazma..");
// Örnek Kullanım 2 :
System.Diagnostics.Trace.WriteLine("Kategori kullanarak trace’e yazma..", "WebUygulaması");
// Örnek Kullanım 3 :
BooleanSwitch boolSwitch = new BooleanSwitch("DBTraceListenerEnabled", "Bool Switch");
System.Diagnostics.Trace.WriteIf(boolSwitch.Enabled, "BooleanSwitch ile trace’e yazma..",
"WebUygulaması");
|
Dikkat ettiğiniz gibi DBTraceListener’i referans vermeden kullanabiliyoruz. Dolayısıyla istediğiniz zaman DBTraceListener’i projeden çıkartabiliyorsunuz ve projeyi tekrar derlemeye gerek kalmıyor.
Sonuç
Uygulamaları izlemek ve hataları daha kolay çözebilmek için kullandığımız TraceListener sınıfını kullanırız.
Web’de bir çok örneğini bulabileceğiniz TraceListener’den türeterek yazılmış trace dinleyicilerine örnek TCP listener uygulaması ve SMTP TraceListener uygulaması verilebilir.
Aynı şekilde hayal gücü ve gereksinimler doğrultusunda çok daha kullanışlı ve yararlı TraceListener’ler yazılabilir.
Kaynaklar
Uygulamayı indirmek için tıklayın.
Makale:
Trace mesajlarının veritabanına yönlendirilmesi - DBTraceListener C#, Visual C# ve .NET Mustafa Erhan Ersoy
|
|
|
-
-
Eklenen Son 10
-
Bu Konuda Geçmiş 10
Bu Konuda Yazılmış Yazılmış 10 Makale Yükleniyor
Son Eklenen 10 Makale Yükleniyor
Bu Konuda Yazılmış Geçmiş Makaleler Yükleniyor
|
|