SCSM 2012 R2 – Grooming Nedir? Ne Amaçla Kullanılır? – Bölüm 1

Bu makalemde oldukça faydalı makaleler olan aşağıdaki üç yazılık serinin benim tarafımdan yorumlanmış üç parçalık Türkçe versiyonlarını buluyor olacaksınız. Kesinlikle okumanızı öneririm. Bahsettiğim üç yazılık seriye ise aşağıdaki linklerden ulaşabilirsiniz.

http://blogs.technet.com/b/ServiceManager/archive/2015/11/16/an-in-depth-look-at-Grooming-in-system-center-Service-Manager-part-1.aspx

http://blogs.technet.com/b/ServiceManager/archive/2015/11/17/an-in-depth-look-at-Grooming-in-system-center-Service-Manager-part-2.aspx

http://blogs.technet.com/b/ServiceManager/archive/2015/11/18/an-in-depth-look-at-Grooming-in-microsoft-system-center-Service-Manager-part-3.aspx

CMDB IT Service altyapısını otomatize etmek için gerekli olan çeşitli Classların, Relationshiplerin ve Metod’ların bulunduğu yerdir.

Arka planda çalışan tüm Tracking ve Keeping işlemleri temp table oluşturmaya ve çok kısa sürelerde data girişi yapmaya ihtiyaç duyarlar. Yapılan bu işlemlerin CMDB performansını ve büyümesini etkilememesi için düzenli olması gerekir. Bu düzeni de Grooming sayesinde sağlarız.

Service Manager mimarisinde bu düzeni sağlamak için bir kaç Grooming job’ı bulunmaktadır. Grooming job’ları arka planda çalışmaktadır fakat çalışan jobları ve yapılarını bilmemiz gerekmektedir.

Neden bu kadar önemli diye soru sorabilirsiniz. Örneğin Grooming job’ları çalışmayıp fail aldığı zaman Service Manager’da performans sorunları yaşamaya başlarsınız. Konsol üzerindeki sıradan Tasklar yavaş çalışmaya başlar, Wworkflowlar’da gecikmeler olur, yada performansa bağlı problemler gün yüzüne çıkar. Grooming jobları kesin olarak durduğunda, Service Manager üzerindeki key tablolar şişer ve bu da bahsettiğimiz performans sorunlarının oluşmasına sebep olur. Bu tablolar oldukça büyük boyutlara ulaştığı zaman da bunları temizleme işlemi her zaman kolay olmaz. Hatta temizleme işleminin riskli olacağı durumlarda microsoft’a support case açmak daha mantıklı olur.

SCSM’yi yöneten kişiler olarak performans problemi yaşadığınızda bunun Groomingden kaynaklanan bir problem olduğunu adresleyebilmeniz gerekir. Bu şekilde sorunu gidermek adına hızlıca harekete geçebilirsiniz.

Service Manager Grooming hakkında bilgi edinmek için başlanacak ilk yer InternalJobHistory tablosudur.Bu tablo düzenli olarak çalışan ve Grooming görevlerini içeren Stored Prosedure’lerin listesini gösterir.


Resim-1

CMDB üzerinde bunların nasıl çalıştığını görmek istiyorsanız ManagedTypeTable‘a bakmanız gerekir.

Aşağıdaki query’i çalıştırıp bunlara bakalım.

SELECT

StoredProcedure

,Criteria

,RetentionPeriodInMinutes

,BatchSize

FROM dbo.MT_GroomingConfiguration


Resim-2

InternalJobHistory hakkında bilgi sahibi olduktan sonra full komutlarına göz atabilirsiniz.

SELECT DISTINCT command

FROM dbo.InternalJobHistory


Resim-3

Yukarıdaki tabloda stored prosedürlerin parametrelerle nasıl çalıştırıldığını görebilirsiniz. Burada ilk parametre genellikle GUID‘dir ve bu GUID Service Manager Managed Type‘tır. Hangi type’ın groome edildiğini öğrenmek istiyorsanız p_GroomManagedEntity stored prosedürüne bakmamız gerekir. Yukarıdaki listedeki bu stored prosedürün kullandığı GUID’lerin Type Name‘lerini aşağıdaki sorgu ile elde edelim. Tablodan p_GroomManagedEntity prosedürünün kullandığı guid’leri alıp işlem yapalım.

SELECT TypeName

FROM ManagedType

WHERE ManagedTypeID IN

(‘E6C9CF6E-D7FE-1B5D-216C-C3F5D2C7670C’

,’D02DC3B6-D709-46F8-CB72-452FA5E082B8′

,’04B69835-6343-4DE2-4B19-6BE08C612989′

,’A604B942-4C7B-2FB2-28DC-61DC6F465C68′

,’422AFC88-5EFF-F4C5-F8F6-E01038CDE67F’)


Resim-4

Görüldüğü gibi tüm workitem class’ları sorgumuz sonucunda listelenmektedir. Bu da bize tüm workitem class’ları üzerinde Grooming işleminin yapıldığını gösterir.

İşlemde kullanılan diğer parametreler için MT_GroomingConfiguration tablosundaki sonuçlara bakabilirsiniz.

İşlemde kullanılan ikinci parametre RetentionPeriodInMinutes, üçüncü parametre Criteria, son parametre ise BatchSize. ‘dır.

Bu prosedürler table’lardaki kilitlenmeyi minimumda tutmak için sık sık büyük miktarda datalar üzerinde çalışır.

GroomingConfiguration tablosu bilgiyi Service Manager üzerindeki Grooming management pack’inden alır. (ServiceManager.Grooming.Configuration.mp).

Diğer stored prosedürlerin (p_GroomStagedChangedLogs ve GroomChangeLogs) System.Entity Managed Types’larını da aynı metod ile öğrenebiliriz.

Bu konuyla ilgili sorularınızı alt kısımda bulunan yorumlar alanını kullanarak sorabilirsiniz.

Referanslar

www.mshowto.org

Yazı gezinmesi

Mobil sürümden çık