Sıklıkla hatalar ile karşılaşıyoruz ve bunları bulmak bir o kadar da zor olmuyor mu? Hata ve Performans İzleme araçlarından bir tanesi de Sentry. Bu yazıda, Sentry’nin nasıl kurulacağını ve performans izlemesiyle nasıl iyileştirmeler yapabileceğimizi anlatacağım. Hazırsan başlıyoruz! 🚀
Aslında genel bir tanımlama yapmak gerekirse; Sentry bir çok uygulamamız için bir hata izleme ve hata raporlama platformu, hatta buna performans raporlaması platformu olduğunu da ekleyebiliriz.
Sentry, geliştiricilere, gerçek zamanlı olarak uygulama hatalarını izlemelerini, hata raporlarını alıp analiz etmelerini ve sorunları hızla teşhis etmelerini sağlar.
Sentry’nin temel özellikleri arasında aşağıdakiler bulunur:
Ayrıca burada ki temel anlatıma ek olarak Onur Dayıbaş’ın Sentry’deki Bazı Kavramlar medium yazısını da okumanızı tavsiye ediyorum.
Öncelikle burada yapacağımız işlemleri görseller ile destekleyeceğim. Zaten Sentry yeterince bu konuda bize yardımcı oluyor olacak.
📌 Sentry’nin sitesine gidip hesap oluşturuyor veya hesabımız var ise giriş yapıyoruz.
📌 Eğer ilk defa giriş yapıyorsanız sizden bir organizasyon oluşturmanızı istiyor. Bunun temel sebeplerinden birisi diğer takım arkadaşlarınız ile de birlikte çalışabilmeniz için istiyor. Bu örnekte “Example” yaparak bu aşamayı geçiyorum.
📌 Kurmak istediğimiz platformu seçeceğimiz ekran karşılıyor bizi. Burada Vue’yü seçiyoruz.
📌 Burada alarm (alert) sıklığını seçiyoruz. Daha sonra bu alanı ayarlamamız mümkün şimdilik “Alert me on every new issue” seçeneğini seçip bir sonraki aşamamız olan proje adımızı oluşturup ve takımımızı seçiyoruz. Bir takım yok ise varsayılan olarak organizasyonuzun adın da bir takım geliyor. Farklı bir takım kurmak isterseniz “+” ya tıklayıp yaratabilirsiniz. “Create Project” diyoruz.
📌 Burada bizim için yönergeleri Sentry veriyor. Burada 3 temel duruma göre otomatik ayarlamaları bizim için yapıyor. Anlamak için önemli noktalar ise şöyle;
Gelelim kurulum aşamasına, aslında yukarıda görselde gösterdiği gibi “npm” yada “yarn” kullanımıza göre projemize Sentry paketimizi kuruyoruz. Daha sonrasında Vue3 örnek kodunu direkt kopyalayıp. “main.js” dosyamıza yapıştırıyoruz. Burası için tabi ki sizin için farklı bir “main.js” dosyanız olabilir. Burada önemli noktalar Sentry.init({])
ile başlayan yeri almamız yeterli (Tabi ki import etmeyi unutmayın). Buradaki ayarlamaların önemli noktaları ve anlamları ise şöyle;
Sentry.BrowserTracing
ve Sentry.Replay
entegrasyonları kullanılır.Görselde gözükmeyen ancak daha detaylı ayarlamalar yapmak istiyorsanız. Sentry Basic Options’a tıklayarak detaylı farklı ayarlamalar yapmanızda mümkün. Temel kurulum işlemlerini aslında burada tamamlamış olduk. Şimdi artık ilk hatamızı nasıl alacağımıza bakalım.
Kurulumları tamamladıktan sonra Sentry bizi otomatik olarak aşağıdaki gibi bir sayfaya yönlendiriyor ve bizden hatalarımızı göndermemizi bekliyor. Aslında tüm hataları burada göreceğiz yada izleyeceğiz.
Peki bu hatayı yada farklı dataları nasıl buraya göndereceğiz?🤔
👩💻 Basit bir button ve fonksiyon oluşturuyoruz.
<button @click="sendSentryData">Click me</button>
function sendSentryData() {
Sentry.captureMessage('Button clicked');
}
Eğer bu fonksiyonu oluşturduğumuzda Sentry’yi import etmemiş ve tanımlamamışsanız. Aşağıda ki görselde ki hatayı alacaksınız.
İlk hatamızı aldık!! Peki bu nasıl oldu?
Çünkü en temelinde bir referans hatası aldığımız ve replaysOnErrorSampleRate değerimiz %100 olduğu için Sentry bunu algılayarak bize direkt olarak gönderdi. İçeriğine tıklayarak hata’nın oluşumunun tekrarını yada detaylı bilgileri öğrenebiliriz, konuyu fazla uzatacağını düşündüğüm için buraya girmiyorum. Hatamız Sentry’yi tanımlamadığımız için almıştık. Bunun için import * as Sentry from '@sentry/vue'
kodunu ekleyerek tanımlamamızı yapıyoruz. Ve butonumuza tekrar tıklıyoruz. 🖱️
Gördüğünüz üzere göndermiş olduğumuz mesajı da görebiliyoruz. Burada ki önemli noktalardan birisi de bu hataya kaç kez kaç kişinin yaşadığını görebiliyor oluşumuz. Events sayısı bu hatanın kaç kez yaşandığını, Users’da ise kaç farklı kullanıcının bu durumu yaşadığını görüyoruz. Burada hataların içerisine girerek detaylı bilgiler öğrenmemiz mümkün. Temel anlamda basit bir hata ve veri gönderme işlemini gerçekleştirmiş olduk. Sıra Performans analizini görmekte.
Bildiğin üzere hepimiz için önemli olan şeylerden birisi de sayfa yükleme hızlarımız yani projemizin gösterdiği performans. Sentry ile bunu analiz etmemizin mümkün olduğundan bahsetmiştik. Kurulum aşamasında Performance Monitoring seçeneğini seçtiysek aslında kurulum aşamasında biraz hız kazanıyoruz. “main.js” dosyamıza geri döndüğümüzde BrowserTracing ve tranceSampleRate değerlerini göreceğiz. BrowserTracing’ de yapacağımız ayarlamalar aslında domainimizin adreslerini girmek. localhost varsayılan olarak geliyor. Bunun yanında deploy ettiğimiz adresi de eklememiz gerekiyor.
Ben örnekleride yapacağım olan “https://moviepal.vercel.app”ı ekledim. Böylece deploy edilmiş halde de performansını ölçüyor olacağım.
Bir diğer değerimiz ise tranceSampleRate bu değerin prod. ortamlarında düşürülmesini öneriyorlar. Tabi ki bir local geliştirme yapıyorsanız bu değerin 1.0 olması öneriliyor. Böylece tüm sayfa yenilemelerinizi analiz etmiş olacaksınız.
Peki bu Perfomance ne işimize yarayacak? Gelin uygulamalı olarak görelim.
Aslında bu projede geliştirmeler yaparken performans eğrilerini kontrol ediyordum. Ve sonra aslında sayfanın yüklenmesinin resimlerden ötürü uzun sürdüğünü fark ettim. Bu konu hakkında UseImage’ı kullanıyordum efektif olacağını düşünüyordum ancak öyle olmamış gözüküyor.
📌 Buradaki yaptığım geliştirme örneklerini Gist üzerinden paylaştım.
📌 Burada ilk yaptığım işlem UseImage’ı kaldırıp düz Img tagı kullanarak durumu izledim.
📌 Görüldüğü üzere değerlerimizde biraz bir düzelme oluyor CLS değeri yükselmiş olsa da diğer parametrelerde %50’yi geçen bir düşme söz konusu. Daha sonra Swiper’ın lazy ve img tag’ının lazy özelliklerini kullanıma açıyorum. Ve TTFB değerimizde ciddi bir düşme söz konusu oluyor.
📌 Daha sonra yine görsellerde gördüğümüz gibi CSS’lerin component içerisinde tekrar tekrar import edilip yüklendiğini fark ediyorum. Ve bunu projemizin ana dizinine global olarak import ediyorum. Böylelikle bu sayfada tekrar tekrar yüklenmesine gerek kalmayacak.
Yaptığımız süreçlerin daha karşılaştırılabilir bir şekilde gösterildiği bir tabloyu aşağıda bulabilirsiniz.👇
Process | Swiper CSS Imported | Event Duration | CLS | FCP | FP | LCP | TTFB | Gist |
---|---|---|---|---|---|---|---|---|
Swiper with UseImage | Yes | 2.93s | 0.226 | 733.4ms | 733.4ms | 1.207s | 80.20ms | Swiper with UseImage |
Swiper with Img Tag | Yes | 2.67s | 0.392 | 383.4ms | 383.4ms | 1.157s | 35.60ms | Swiper with Img Tag |
Swiper with Img and Lazy | Yes | 2.06s | 0.253ms | 391ms | 391ms | 791.5ms | 18.60ms | Swiper with Img and Lazy |
Swiper with Img and Lazy | No | 1.78s | 0.218ms | 312.9ms | 312.9ms | 693.7ms | 8ms | Swiper with Img and Lazy without CSS |
Swiper CSS Imported: Swiper CSS’lerinin sayfa içerisinde tekrar çağırılıp çağrılmadığını gösterir. Eğer değer “No” ise projenin ana dizinin de çağırılmıştır.
Kısaltmalar ve metrikler hakkında bilginizin yeterli olmadığını düşünüyorsanız. Google web.dev sizin için faydalı olabilir.
Görüldüğü üzere, Sentry’nin sağladığı Performans İzleme aracını kullanarak basit bir örnek oluşturduk ve kodumuzu daha optimize hale getirdik. Elbette farklı optimizasyon yöntemleri bulunmaktadır, ancak burada yaptığımız bazı basit düzeltmeler ve Sentry aracılığıyla sayfa yükleme hızımızı önemli ölçüde artırdık.
Bu iyileştirmelerle sayfa yükleme hızımızı yaklaşık olarak %60 oranında artırmış olduk.
Bu yazımda Sentry’nin kullanımı ve kurulumunun nasıl yapılacağına bize nasıl faydalı olacağına dair örnekler yaparak sizlere anlatmaya çalıştım.
Medium yazımı okuduktan sonra Linkedin hesabımdan sorularınız yada önerileriniz var ise ulaşabilirsiniz.
Bir sonraki yazımda görüşmek üzere 📩