Bu makale bir önceki makale yapmış olduğumuz ikinci bir log dosyası oluşturduktan sonra ilk log dosyasında sorun giderilip, tekrardan eski yapımıza geçmek için sonradan oluşturulan ikinci log dosyamızdaki veriler ilk log dosyamızın üzerine yazılıp daha sonra ikinci log dosyamızı silme işlemini ele alacağız.Neden ikinci bir log dosyası oluşturmamız gerektiğini ikinci bir log dosyası oluşturmak konulu makalemde belirtmiştim. Bu yapıyı sağlayacak olan shrink işleminde 3. Kısımda bulunan Empty file by migrating the data to other files in the same filegroup yöntemi olmuş olacak.
Şimdi uygulamalı bir şekilde oluşturmuş olduğum ikinci log dosyasını ilk log dosyası üzerine atalım.
İkinci log dosyasında shrink işlemi yaparak boş alanları işletim sistemini iade ediyorum. Log dosyasının boşalması için shrink işleminden önce bir log backup alıyorum.
Log backup aldıktan sonra veritabanının üzerine sağ tıklayıp Task>Shrink>Files sekmesine geliyorum.
Gelen ekranda file type kısmında log seçtikten sonra file name kısmında shrink yapacağımız ikinci log dosyamızı seçiyorum. Shrink action bölümünde Empty file by migrating the data to other files in the same filegroup seçeneğini seçiyoruz. Bu şekilde log dosyamızın içindeki verilerin diğer log dosyasına aktarılmasını sağlamış oluyoruz.
Shrink action kısmından da, Empty file by migrating the data to other files in the same filegroup seçeneğini seçiyoruz. Bu şekilde log dosyamızın içindeki verilerin diğer log dosyasına aktarılmasını sağlamış oluyoruz.
Yukarıdaki arayüzün script’ini alıyoruz. Silme işlemiyle aynı anda yapmamız gerekiyor log dosyasına herhangi bir veri yazılmasın.
USE [TEST2] GO DBCC SHRINKFILE (N'TEST2_log2 ' , EMPTYFILE) GO
Yukarıdaki çıktıyı aldıktan sonra ilgili database üzerine sağ tıklayıp properties ekranından ilgili log dosyasının silme işlemi için create script’ini alıyorum. Remove deyip sildikten sonra üst tarafta bulunan script kısmına tıklıyorum. Script’ini bu şekilde alıyoruz.
use [master]; GO USE [TEST2] GO ALTER DATABASE [TEST2] REMOVE FILE [TEST2_log2 ] GO
Hem shrink işlemi için aldığımız kodu hem de ikinci log dosyasını silme script’ini alt alta alıyorum.
USE [TEST2] GO DBCC SHRINKFILE (N'TEST2_log2 ' , EMPTYFILE) GO
use [master]; GO USE [TEST2] GO ALTER DATABASE [TEST2] REMOVE FILE [TEST2_log2 ] GO
Komutu çalıştırdıktan sonra ilk log dosyamın enable autogrowth değerini aktif ediyorum.
Bu işlemleri yaptıktan sonra veritabanı altında silmemize rağmen ikinci log uzantısı görülmeye devam edecektir. Belli süre sonra tek log dosyasının olduğunu göreceksiniz.
Artık veritabanımız ilk log dosyasından büyümeye devam etmiş oluyor. Veritabanı altında gereksiz yere oluşan log yığınından kurtulmuş oluyoruz.
0 Yorum