Instance sayınız ve veritabanı sayınız arttığında tüm veritabanlarınızın toplam boyutunu bulmak biraz zorlaşabilir. Bazen yöneticiniz sql server veritabanlarının toplam boyutu hakkında sizden bilgi isteyebilirler. Böyle bir durumda eğer instance sayınız azsa ve high availability çözümlerinden birini kullanmıyorsanız aşağıdaki script’i kullanarak instance bazında tüm veritabanlarının toplam boyutunu bulabilirsiniz.
with fs as ( select database_id, type, size * 8.0 / 1024/1024 size from sys.master_files ) select name, (select sum(size) from fs where type = 0 and fs.database_id = db.database_id) + (select sum(size) from fs where type = 1 and fs.database_id = db.database_id) DBSizeGB from sys.databases db where (select sum(size) from fs where type = 1 and fs.database_id = db.database_id) is not null order by DBSizeGB desc
Mesela benim çalıştırdığım instance’da yukardaki script’in sonucunda 30 kayıt geldi. Ama unutmayalım bu script standalone ve always on’un secondary veritabanlarının hepsini içeriyor.
Bazı sistemlerde always on kullanan instance’ların içersinde always on’a dahil olmayan veritabanları da oluyor. Bu yüzden bu script’i hem primary hem de secondary instance’da çalıştırmanız gerekir. Böyle olduğunda da always on’a dahil veritabanlarının boyutunu 2 kere hesaplamış oluyorsunuz.
Script’i aşağıdaki şekle çevirince o instance üzerindeki aktif tüm veritabanlarının(always on’a dahil bir veritabanıysa primary olduğu takdirde listeye giriyor. Always On’a dahil olmayan(standalone) veritabanları da listeye giriyor.) isimleri ve büyüklüklerini listeliyor.
with fs as ( select database_id, type, size * 8.0 / 1024/1024 size from sys.master_files where database_id IN ( SELECT DISTINCT DB_ID(dbcs.database_name) AS veritabaniid FROM master.sys.availability_groups AS AG LEFT OUTER JOIN master.sys.dm_hadr_availability_group_states as agstates ON AG.group_id = agstates.group_id INNER JOIN master.sys.availability_replicas AS AR ON AG.group_id = AR.group_id INNER JOIN master.sys.dm_hadr_availability_replica_states AS arstates ON AR.replica_id = arstates.replica_id AND arstates.is_local = 1 INNER JOIN master.sys.dm_hadr_database_replica_cluster_states AS dbcs ON arstates.replica_id = dbcs.replica_id LEFT OUTER JOIN master.sys.dm_hadr_database_replica_states AS dbrs ON dbcs.replica_id = dbrs.replica_id AND dbcs.group_database_id = dbrs.group_database_id WHERE ISNULL(arstates.role, 3) = 1 union all select DB_ID(name) veritabaniid from sys.databases where replica_id is null and database_id >4 ) ) select name, (select sum(size) from fs where type = 0 and fs.database_id = db.database_id) + (select sum(size) from fs where type = 1 and fs.database_id = db.database_id) DBSizeGB from sys.databases db where (select sum(size) from fs where type = 1 and fs.database_id = db.database_id) is not null order by DBSizeGB desc
Yukardaki script kısmen işimizi görür. Elimizde bütün instance’larda (içinde always on’a dahil olan veritabanı olsun olmasın) bu script’i çalıştırıp tüm veritabanlarının boyutunu toplayabiliriz. Yukardaki script’in çalışması sonucundaki ekran görüntüsünü aşağıda bulabilirsiniz. Gördüğünüz gibi 12 kayıt geldi. Demekki 30 veritabanından 18 tanesi ya always on’un secondary veritabanıymış ya da sistem veritabanıymış(bu script’te sistem veritabanlarını da çıkarıyoruz) Bu script’i always on kullanan instance’larda hem primary hem de secondary instance’da çalıştırıp çıkan sonucu toplamalısınız.
İşimizi biraz daha kolaylaştıralım. O instance üzerindeki veritabanlarını manual olarak toplamak yerine bir cursor içersinde döndürerek sql server’a toplattıralım. Aşağıdaki script yardımıyla da bir instance üzerindeki tüm veritabanlarının(always on’a dahil bir veritabanıysa primary olduğu takdirde listeye giriyor. Always On’a dahil olmayan(standalone) veritabanları da listeye giriyor.) toplam boyutunu veriyor.
DECLARE @size int DECLARE @totalsize int set @totalsize=0 DECLARE db_cursor CURSOR FOR with fs as ( select database_id, type, size * 8.0 / 1024/1024 size from sys.master_files where database_id IN ( SELECT DISTINCT DB_ID(dbcs.database_name) AS veritabaniid FROM master.sys.availability_groups AS AG LEFT OUTER JOIN master.sys.dm_hadr_availability_group_states as agstates ON AG.group_id = agstates.group_id INNER JOIN master.sys.availability_replicas AS AR ON AG.group_id = AR.group_id INNER JOIN master.sys.dm_hadr_availability_replica_states AS arstates ON AR.replica_id = arstates.replica_id AND arstates.is_local = 1 INNER JOIN master.sys.dm_hadr_database_replica_cluster_states AS dbcs ON arstates.replica_id = dbcs.replica_id LEFT OUTER JOIN master.sys.dm_hadr_database_replica_states AS dbrs ON dbcs.replica_id = dbrs.replica_id AND dbcs.group_database_id = dbrs.group_database_id WHERE ISNULL(arstates.role, 3) = 1 union all select DB_ID(name) veritabaniid from sys.databases where replica_id is null and database_id >4 ) ) select (select sum(size) from fs where type = 0 and fs.database_id = db.database_id) + (select sum(size) from fs where type = 1 and fs.database_id = db.database_id) DBSizeGB from sys.databases db where (select sum(size) from fs where type = 1 and fs.database_id = db.database_id) is not null order by DBSizeGB desc OPEN db_cursor FETCH NEXT FROM db_cursor INTO @size WHILE @@FETCH_STATUS = 0 BEGIN SET @totalsize= @totalsize+@size FETCH NEXT FROM db_cursor INTO @size END CLOSE db_cursor DEALLOCATE db_cursor select @totalsize
Yukardaki script’in sonucunun ekran çıktısınıda aşağıdaki ekran görüntüsünde görebilirsiniz. Bir önceki script’te çıkan sonuçları toplayarak o instance üzerindeki toplam boyutu GB türünden veriyor.
Peki benim birden fazla 10 tane ya da daha fazla instance’ım varsa tek tek bu instance’lara bağlanarak bu script’i çalıştırmam mı gerekiyor?
Hayır. Bütün instance’larınızı Registered Servers’a kaydererek tek bir seferde hepsi için hesaplatabilirsiniz. Registered Servers ile ilgili detaylara “ Registered Server ile Birden Fazla Instance Üzerinde Aynı Script’i Çalıştırmak ” isimli makalemden ulaşabilirsiniz.
Registered Servers’a aşağıdaki gibi sağ tıklayarak new query diyerek yukardaki sorguyu çalıştırdığınızda tek bir seferde tüm instance’larınızdaki veritabanı boyutlarınızın toplamını bulabilirsiniz. Tabi bu sorguyu registered server ile çalıştırdığınız da registered server’ınızda kaç tane instance varsa o kadar satır dönecektir. O satırların hepsini toplayarak toplam veritabanı boyutunuzu bulabilirsiniz.