SQL Server DMV ve DMF Kavramları ve Kullanımları -1

Merhaba Arkadaşlar,

Bu ve bundan sonraki 5-10 yazımda sizlere SQL Server Veritabanlarında DMV ( Dynamic Management Views ) ve DMF ( Dynamic Management Functions ) kavramlarını, bunların kullanımını örneklerle anlatacağım. SQL Server 2005 ile tanıtılan DMV ve DMF ler sayesinde veritabanlarında meydana gelen aktiviteleri izleyebilir, performansını görebilir ve kısaca veritabanlarını yönetmemiz için gerekli sistem bilgilerini görüntüleyebiliriz.

sql server dmv2

 

Tüm Veritabanları ( Oracle, SQL Server, MySQL,Sybase,PostreSQL, DB2 vbvb.. ) üzerinde koşan aktiviteleri ve bunların istatistiklerini sistem hakkında bilgi toplamak isteyenlere sunmak amacıyla sistem tablolarında toplarlar. Sistem hakkında bilgi edinmemiz için SQL Server tarafından belli aralıklarla güncellenen sistem tablolarında genel itibariyle aşağıdaki bilgiler mevcuttur.

  • Veritabanı ve Veritabanı Sunucusu hakkında Genel bilgiler ( Adı, Sürümü, versiyonu vbvb.. )
  • Aktif Çalışan Sorgular
  • Aktif Çalışan Sorguların CPU, I/O ve Memory kullanımları
  • Çalışan Bir Sorgunun kullandığı Execution Plan
  • Çalışan Bir Sorgunun kullandığı index
  • Memory, Disk ve Network teki I/O beklemeleri
  • Sistemin Performansını kötü etkileyen Index ler  ( Missing Index ler )
  • Indexlerin Kullanım oranları ( Scan, Seek değerleri )
  • Disklerin Cevap verme süreleri ( Response time )

SQL Server da DMV ve DMF ler aynı görevi görmelerine rağmen aralarında ki fark DMV ( Dynamic Management Views )  adından da anlaşıldığı gibi direk sorgulanabilirken DMF  ler ( Dynamic Management Functions ) ise yine adından anlaşılacağı üzere bir parametre alıp buna göre bir tablo döndüren fonksiyonlardır.

sql server dmv

DMV ve DMF ler sayesinde Production ortamında çalışan kritik veritabanlarımızı İzleyip, oluşan problemleri hemen belirleyebilir ve buna göre aksiyon alabiliriz. Bu sorgularla Veritabanında aktif çalışan sorgulardan en çok CPU, I/O ve Memory Tüketen sorguları öğrenebilir, Index i eksik olan tabloları bulabilir ve Yavaş çalışan sorguları tespit edebiliriz.

Bu sorunları tespit ettikten sonra Performance tuning adına gerekli aksiyonları alabiliriz. Örneğin, veritabanında şuanda çalışan sorgular içerisinde en çok CPU tüketen sorguları bulup ilgili sorgularda SQL Tuning yapabiliriz. Sorguların Execution Planından Index i bulunmayan yada bozuk olan ve Index e ihtiyaç duyan yada indexinin düzeltilmesi gereken bir tabloyu tespit ettikten sonra tabloya gerekli index i atabilir yada indexi düzeltebiliriz. Öte yandan Veritabanındaki sorun Memory kaynaklı ise ve sistemde veritabanı için ayrılan memory yeterliyse, memory i düzgün kullanma adına memory parametreleri yeniden gözden geçirilebilir.

SQL Server da var olan Tüm DMV ve DMF leri aşağıdaki sorguyla öğrenebiliriz.

select name,type_desc from sys.system_objects where name like 'dm%' order by name;

DMV1.jpg

SQL Server daki kullanılan bu DMV ve DMF ler Session, Database, OS (Operating System), Transaction vbvb kategorilerinde kullanıcılara bilgiler sunmaktadırlar. Örneğin; Database seviyesindeki DMV ve DMF ler sys.dm_db ile başlarlar yada Transactionlarla ilgili DMV ve DMF ler sys.dm_tran ile başlarlar. Kategorilere göre DMV ve DMF ler listesi aşağıdaki gibidir.

DMV2

Yukardaki DMV ve DMF lerden en çok kullanılan ve benimde en çok kullandığım DMV ve DMF lerden bazıları aşağıdaki gibidir.

Session ve Processler için DMV ve DMF: Aktif çalışan sorguların, process lerin hangi kullanıcı ile hangi makinadan geldiğini, tahmini bitiş süreleri ve Sorgu istatistikleri gibi bilgileri veren DMV ve DMF lerdir. Bunlardan önemli olanları aşağıdaki gibidir.

  • sys.dm_exec_query_stats (DMV)
  • —sys.dm_exec_requests— (DMV)
  • sys.dm_exec_sessions (DMV)
  • sys.dm_exec_connections (DMV)
  • sys.dm_exec_query_plan (DMF)
  • —sys.dm_exec_sql_text (DMF)
  • sys.dm_exec_cached_plans (DMV)
  • sys.dm_exec_cursors (DMF)

Database seviyesindeki DMV ve DMF: Veritabanı seviyesinde ki Index,Mirroring,partitioning gibi konularda gerekli bilgileri veren DMV ve DMF lerdir. Bunlardan önemli olanları aşağıdaki gibidir.

  • sys.dm_db_missing_index_details ( DMV)
  • sys.dm_db_missing_index_columns ( DMF )
  • —sys.dm_db_missing_index_groups (DMV—)
  • sys.dm_db_missing_index_group_stats (DMV)
  • sys.dm_db_index_usage_stats (DMV)
  • sys.dm_db_index_physical_stats (DMF)
  • sys.dm_db_index_operational_stats (DMF)
  • dm_db_partition_stats (DMV)
  • sys.dm_db_mirroring_connections (DMV)
Operating System (İşletim Sistemi )DMV ve DMF leri: Veritabanının bulunduğu işletim sistemi üzerindeki bilgilerin toplandığı DMV ve DMF lerdir. Bunlardan önemli olanları aşağıdaki gibidir.
  • sys.dm_os_sys_info (DMV)
  • sys.dm_os_sys_memory(DMV)
  • sys.dm_os_waiting_tasks(DMV)
  • sys.dm_os_wait_stats(DMV)
  • sys.dm_os_waiting_tasks (DMV)
  • sys.dm_os_performance_counters(DMV)
  • sys.dm_os_cluster_nodes (DMF)
Transaction DMV ve DMF leri: Veritabanında meydana gelen Transactionlarla ilgili bilgilerin sorgulanabileceği DMV ve DMF lerdir. Bunlardan önemli olanları aşağıdaki gibidir.
  • sys.dm_tran_active_transactions (DMV)
  • sys.dm_tran_session_transactions (DMV)
  • sys.dm_tran_database_transactions (DMV)
  • sys.dm_tran_current_transaction (DMV)
Böylece bu yazının da sonuna gelmiş bulunmaktayım bundan sonraki  SQL Server yazılarımda DMV ve DMF konusuna devam edip bu konu ile ilgili ayrıntılı scriptlerle örnek vereceğim şimdiden esen kalın.
Oracle Exadata SQL Server Goldengate Weblogic EBS ve Linux konusunda aşağıdaki konularda 7×24 Uzman Danışmanlara yada Eğitimlere mi İhtiyacınız var [email protected] adresine mail atarak Bizimle iletişime geçebilirsiniz.– Oracle Veritabanı Danışmanlığı
– Oracle Veritabanı Bakım ve Destek
– Exadata Danışmanlığı
– Exadata Bakım ve Destek
– SQL Server Veritabanı Danışmanlığı
– SQL Server Veritabanı Bakım ve Destek
– Goldengate Danışmanlığı
– Goldengate Bakım ve Destek
– Linux Danışmanlığı
– Linux Bakım ve Destek
– Oracle EBS Danışmanlığı
– Oracle EBS Bakım ve Destek
– Weblogic Danışmanlığı
– Weblogic Bakım ve Destek
– Oracle Veritabanı Eğitimleri
– Oracle VM Server Danışmanlığı
– Oracle VM Server Bakım ve Destek
– Oracle EPPM Danışmanlığı
– Oracle EPPM Bakım ve Destek
– Oracle Primavera Danışmanlığı
– Oracle Primavera Bakım ve Destek
– Oracle Eğitimleri
– SQL Server Eğitimleri
– Goldengate Eğitimleri
– Exadata Eğitimleri
– Linux Eğitimleri
– Oracle EBS Eğitimleri
– Oracle VM Server Eğitimleri
– Weblogic Eğitimleri
– Oracle EPPM Eğitimleri
– Oracle Primavera Eğitimleri

About Mehmet Salih Deveci

I am Founder of SysDBASoft IT and IT Tutorial and Certified Expert about Oracle & SQL Server database, Goldengate, Exadata Machine, Oracle Database Appliance administrator with 10+years experience.I have OCA, OCP, OCE RAC Expert Certificates I have worked 100+ Banking, Insurance, Finance, Telco and etc. clients as a Consultant, Insource or Outsource.I have done 200+ Operations in this clients such as Exadata Installation & PoC & Migration & Upgrade, Oracle & SQL Server Database Upgrade, Oracle RAC Installation, SQL Server AlwaysOn Installation, Database Migration, Disaster Recovery, Backup Restore, Performance Tuning, Periodic Healthchecks.I have done 2000+ Table replication with Goldengate or SQL Server Replication tool for DWH Databases in many clients.If you need Oracle DBA, SQL Server DBA, APPS DBA,  Exadata, Goldengate, EBS Consultancy and Training you can send my email adress [email protected].-                                                                                                                                                                                                                                                 -Oracle DBA, SQL Server DBA, APPS DBA,  Exadata, Goldengate, EBS ve linux Danışmanlık ve Eğitim için  [email protected] a mail atabilirsiniz.

2 comments

  1. An impressive share, I just given this onto a colleague who was doing a little analysis on this. And he in fact bought me breakfast because I found it for him.. smile. So let me reword that: Thnx for the treat! But yeah Thnkx for spending the time to discuss this, I feel strongly about it and love reading more on this topic. If possible, as you become expertise, would you mind updating your blog with more details? It is highly helpful for me. Big thumb up for this blog post!

Leave a Reply

Your email address will not be published. Required fields are marked *