Ana içeriğe atla

Powershell Kullanarak Windows Features Yönetimi (Import And Export)

Bu yazı Windows Server 2008, Windows Server 2008 R2, Windows Server 2012, Windows Server 2012 R2 ve Windows Server 2016 işletim sistemleri üzerinde kullanılabilecek bilgiler içerir. Yazıyı okumaya başlamadan önce yazı içerisinde kullanılacak Get-WindowsFeature ve Add-WindowsFeature cmdletleriyle ilgili detaylı bilgileri inceleyebilirsiniz. Kendi ortamınızda test yapmadan önce ServerManager modülünü import etmelisiniz, Import-Module cmdlet için de yine MSDN üzerindeki bilgilerden faydalanabilirsiniz. Umarım faydalı bir yazı olmuştur. Birden fazla sunucuya benzer kurulumları yapmak istediğimizde karşımıza operasyonel zorluklar çıkabiliyor. Bu işlemleri hızlandırmanın & standart bir hale getirmenin bir çok yolu var ancak bu yazıda bir sunucu üzerinde kurulu Windows Feature'ların powershell ile toplanarak, diğer bir sunucuda kurulması için en basit olduğunu düşündüğüm yöntemi paylaşacağım. İlk olarak servermanager modülünün Powershell sessionımıza import edilmesi gerekmektedir.
Import-Module ServerManager
Yüklü bileşenleri alacağımız sunucuda aşağıdaki powershell komutunu çalıştırdığımızda yüklü windows feature bileşenlerinin tamamını görebiliriz.
Get-WindowsFeature | Where-Object {$_.Installed}
Bu komuttan yola çıkarak, yüklü bileşenleri bir text dosyasına kaydedeceğiz.
Get-WindowsFeature | Where-Object {$_.Installed} | Select Name | ForEach-Object { $_.Name } | Out-File .\InstalledWindowsFeatures.txt
Not: Dosyanın export edildiği lokasyonu komutun en başındaki path bilgisinden edinebileceğimiz gibi aşağıdaki komut ile de edinebilirsiniz.
(Get-Item -Path ".\" -Verbose).FullName
Windows Feature bileşenlerinin dosyaya kaydettikten sonra bu bileşenleri install edeceğimiz sunucunun erişimi olan bir klasöre dosya kopyalanmalıdır. Ben D:\ drive altından okuyacak şekilde aşağıdaki gibi kullandım.
$(Get-Content D:\InstalledWindowsFeatures.txt) | Add-WindowsFeature
Eğer yazının başında belirttiğim gibi yeni bir sessionda servermanager modülünü import etmediyseniz, muhtemelen bu komutta hata almış olacaksınız. Windows Feature'ları yeni sunucuda yüklemeden önce Import-Module ServerManager komutuyla modülü import etmeyi unutmayınız.

Remote Session kullanarak yüklemek için aşağıdaki koumutları kullanabilirsiniz.

Kaynak sunucuda yüklü bileşenleri aldıktan sonra dosyayı karşı sunucuya kopyalamak için öncelikle aşağıdaki komutu kullanalım.
copy .\InstalledWindowsFeatures.txt \\sccmtstapp04\d$\InstalledWindowsFeatures.txt
Bu komutu çalıştırdıktan sonra Enter-PSSession cmdleti kullanarak uzaktaki sunucunun powershell sessionına baglantı kuruyoruz.
Enter-PSSession Server2
Son olarak remote sessionda Windows Feature'ları yeni sunucuda install ediyor olacağız.
$(Get-Content D:\InstalledWindowsFeatures.txt) | Add-WindowsFeature


Herkese kolay gelsin.

Yorumlar

Bu blogdaki popüler yayınlar

gMSA (group managed service account) and SQL Server

MSA (managed user account) teknolojisinin sorunlarından bir tanesi aynı MSA'i birden fazla computer objesinde kullanamamaktı. Bu nedenle de gMSA (group managed service account) duyuruldu. gMSA ile; Passwordler Active Directory tarafından yönetileceği için complex olurlar ve sık sık otomatik olarak değiştirilir (default 30 days). Passwordler 240 bytes uzunluğunda randomly şifrelenmiş olarak üretilir. Ek olarak interactive logon amaçlı kullanılamazlar, yanlış şifre girilmesi sonucunda meydana gelen lock-out olma durumuna yakalnmazlar. Şifre değişikliği sonrasında SQL Server Servisinin restart edilmesine gerek bulunmaz. Aşağıda belirtilen adımlar pre-reqlerin tamamlanmış olduğu varsayılarak step by step aktarılmıştır. Prerequisetlerle ilgili detaylı bilgilendirmeye  https://technet.microsoft.com/en-us/library/jj128431.aspx#BKMK_gMSA_Req  linkinden erişilebilir. 1-  Active Directory Users and Computers Altında Global Security Group Oluşturma gMSA 'i kullanacağım...

VbScript ile Local Kullanici Yönetimi (Change Local User Password)

Bu yazı Windows Server 2008, Windows Server 2008 R2, Windows Server 2012, Windows Server 2012 R2 ve Windows Server 2016 işletim sistemleri üzerinde kullanılabilecek bilgiler içerir. Birden fazla sunucuda ya da bilgisayar üzerinde işlem yapmak otomasyon ve scripting gerektiren bir süreçtir. İhtiyaç dahilinde yazmış olduğum scriptle txt uzantılı bir dosyadan sunucu isimleri teker teker okunarak, loop döngüsü içerisinde sunuculara bağlantı kuruluyor ve şifresi değiştirilmek istenilen local kullanıcının sistemde tanımlı olup olmadığı kontrol ediliyor. Eğer local kullanıcı yok ise kullanıcı verilen şifre ile create edilerek administrators lokal grubuna dahil ediliyor, kullanıcı sistemde tanımlı ise şifresi yeni şifreyle değiştiriliyor. Set objFSO = CreateObject("Scripting.FileSystemObject") Set objTextFile = objFSO.OpenTextFile("D:\computerlist.txt", 1) myUserName = "myUser" myPassword = "myNewP@$$w0rd" Do Until objTextFile.AtEndOfStream ...

Fun With Docker.. Jenkins Edition

D ocker son zamanların kaçınılmaz bir şekilde moda haline gelen teknolojisi, ben de işimin parçası olan jenkins, ansible, elastic stack yapılarını docker ile kendi ortamımda ayağa kaldırarak bazı testler yapmaya karar verdim. Bu sırada Jenkins için izlediğim yolu da sizlerle paylaşmak istedim. Öncelikle docker for windows için community (ce) edition ‘ı download ederek bilgisayarımıza kurmamız gerekiyor. https://www.docker.com/docker-windows Docker for Windows kurulumunu tamamladıktan sonra geriye sadece kurmak istediğimiz imajı repositoryde aratmak kalıyor. Ben CI ve CD akışlarımda kullanmak için Jenkins’i kurmayı tercih etmiştim. Sizinle de Jenkins için kurulum ekran görüntülerini paylaşıyorum. Öncelikle komutlarımızı çalıştırabilmek için Powershell’i run as administrator moduyla açmalıyız. Powershell açıldıktan sonra “docker pull jenkins” yazarak enter tuşuna basmamız Jenkins imajının indirilmesi için yeterli olacaktır. Bu aşamada pull işleminin ta...