Definition

Was ist PowerShell?

| Autor / Redakteur: tutanch / Andreas Donner

(© aga7ta - Fotolia)

PowerShell ist eine objektorientierte Skript- und Programmiersprache für Windows mit eigenem Command Line Interface. Es lassen sich mit ihrer Hilfe Aufgaben automatisieren und Tools entwickeln. Seit 2016 ist sie als Open-Source-Projekt plattformübergreifend für weitere Betriebssysteme verfügbar.

Die PowerShell stellt eine interaktive Befehlszeilen-Shell für Windows-Systeme zur Verfügung und kann als Nachfolger der Eingabeaufforderung verstanden werden. Sie ist jedoch wesentlich mächtiger und bietet einen um ein Vielfaches größeren Funktions- und Befehlsumfang. Mit der Shell lassen sich zahlreiche Aufgaben auf den Systemen automatisieren.

Häufig kommt sie für das Systemmanagement und die Verwaltung von Windows-basierten Client-Server-Systemen zum Einsatz. Die Befehle der PowerShell nennen sich Cmdlets. Für die Erstellung von Skripten ist ein umfassender Satz von Kontroll- und Logikstrukturen wie Schleifen oder if-Abfragen, regulären Ausdrücken, Befehlen zur Zeichenverarbeitung oder arithmetischen Funktionen vorhanden.

Skripte bestehen aus den Cmdlets und zugehörigen Logikfunktionen und -ausdrücken. Im Kern arbeitet die PowerShell objektorientiert. Dadurch stehen ihr beispielsweise alle COM-Objekte und das gesamte .NET Framework zur Verfügung. Ebenfalls möglich ist der Zugriff auf die Windows Management Instrumentation (WMI), mit der sich umfassende Systeminformationen abfragen lassen.

Befehle und Skripte können über ein Netzwerk hinweg remote auf fremden Rechnern ausgeführt werden. Dadurch eignet sich die Shell bestens für Administrationsaufgaben in einem Rechnernetz. Grundsätzlich verbindet die Shell die objektorientierte Programmierung mit den von Unix-Shells bekannten Pipe- und Filterfunktionen. Anwender der Shell können sowohl komplexe Skripte programmieren als auch einfache Kommandozeilenbefehle ausführen und untereinander verknüpfen. Die PowerShell ist ein kostenloser Bestandteil aktueller und vergangener Windows-Versionen.

Die PowerShell: Open Source und plattformübergreifend

2016 gab Microsoft bekannt, dass die Shell plattformübergreifend für verschiedene Betriebssysteme verfügbar werden soll. Es wurden unter Open-Source-Lizenz erste Alpha-Versionen der PowerShell 6.0 für Linux und macOS veröffentlicht. Hintergrund der plattformübergreifenden Strategie von Microsoft sind die Cloud-Aktivitäten des Konzerns, bei denen neben Windows-Rechnern auch Linux-Systeme bereitgestellt werden. Die Shell soll zu einem universell einsetzbaren Tool für Administratoren werden – unabhängig vom verwendeten Betriebssystem.

Die verschiedenen Versionen der Windows Shell

Bereits seit Windows XP ist die PowerShell als kostenloser Download von Microsoft verfügbar. Auch für alle nachfolgenden Windows-Versionen kann die Shell genutzt werden. Sie ist ebenfalls für die Server-Betriebssysteme wie Windows Server 2003, Windows Server 2008 oder Windows Server 2012/2012 R2 erhältlich. Hier ein kurzer Überblick über die bisherigen Versionen:

  • Version 1.0 (2006) für Windows XP und höher
  • Version 2.0 (2009) für Windows XP und höher
  • Version 3.0 (2012) für Windows 7, Windows Server 2008 und höher
  • Version 4.0 (2013) für Windows 7, Windows Server 2008 und höher
  • Version 5.0 (2015) für Windows 7, Windows 8.1, Windows 10 ...
  • Version 5.1 (2016) für Windows 7, Windows 8.1, Windows 10, Windows Server 2008 R2, 2012, 2012 R2, Windows Server 2016 ...

Die zentralen Funktionen der PowerShell

Im Folgenden kurz zusammengefasst die zentralen Funktionen der Shell:

  • umfangreiche Befehlssammlung (Cmdlets)
  • Zugang zu sämtlichen Systemobjekten des .NET Frameworks, der COM-Bibliotheken und der Windows Management Instrumentation (WMI)
  • Weitergabe von objektorientierten Ausgaben der Cmdlets über Pipelines
  • mächtige und einfach zu erlernende Skriptsprache mit umfangreichen Logik- und Steuerfunktionen
  • Implementierung eines Sicherheitsmodells zur Verhinderung des unerwünschten Ausführens von Skripten
  • Funktionen für das Debugging und die Verfolgung des Skriptablaufs
  • separater Skripteditor und Debugger in Form des Windows PowerShell ISE
  • Erweiterung des Befehlssatzes um eigene Befehle möglich
  • Integration in eigene Anwendungen per Hosting möglich

Cmdlets – die Befehle der PowerShell-Umgebung

Die Befehle der Shell-Umgebung nennen sich Cmdlets, ausgesprochen Commandlets. Die Cmdlets sind keine Stand-Alone-Anwendungen, sondern nur innerhalb der PowerShell-Umgebung ausführbar. Sie lassen sich direkt im Command Line Interface (CLI) eingeben. Die Ergebnisse der Cmdlets sind Objekte, die mit weiteren Befehlen verarbeitet werden können.

Die Syntax der Cmdlets richtet sich nach einer Verb-Nomen-Struktur. Durch das vorangestellte Verb orientieren sich die Cmdlets an verschiedenen Aufgaben. Beispiele für Befehle dieser Art sind Get-Process, Stop-Process, Select-Object, Move-Item oder Copy-Item. Im Command Line Interface werden unvollständig eingegebene Kommandos wie Get-It durch drücken der Tabulator-Taste vervollständigt (in diesem Fall zu Get-Item). Ebenfalls möglich sind Abkürzungen der Befehle beispielsweise gps für Get-Process, mi für Move-Item oder gi für Get-Item. Mit dem Cmdlet Get-Command kann eine Liste aller Cmdlets ausgegeben werden. Dank der strikten und exakt definierten Syntax und sauberer Namenskonventionen der Cmdlets sind Skripte und Befehle recht gut lesbar und gut strukturiert.

Das Konzept der Pipelines in der PowerShell

Die PowerShell bietet das aus der Unix-Welt bekannte Konzept der Pipelines. Mit einer Pipeline kann die Ausgabe eines Kommandos (Cmdlets) an ein nächstes übergeben und dort weiterverarbeitet werden. Hierfür ist es erforderlich, die beiden Cmdlets über den Pipe-Operator (das Zeichen "|") miteinander zu verbinden. Beispielsweise ist es mit Pipelining möglich, Dateien eines Verzeichnisses abhängig von ihrer Größe sortiert auszugeben. Die Kommandozeile in der Shell muss hierfür folgendermaßen aussehen:

> Get-ChildItem C:/TEMP -Recurse | Sort-Object Length -Descending | Select-Object Fullname, Length -First 3

In dieser Befehlszeile sind die Cmdlets für das Auslesen des Verzeichnisses (Get-Childitem), das Sortieren des Ergebnisses (Sort-Object) und das Auswählen der ersten drei Dateinamen mit Größenangabe (Select-Object) per Pipe miteinander verbunden. Da die Ausgabe der einzelnen Befehle jeweils objektorientiert und nicht als reiner Daten-String erfolgt, ist die jeweils nachfolgende Verarbeitung durch das nächste Kommando sehr einfach zu realisieren. Im Vergleich zu rein textbasiert arbeitenden Shells entfällt der zusätzliche Aufwand für das Parsen und Manipulieren der Textausgaben.

Die Windows PowerShell ISE als Skripteditor und Debugger der Shell-Umgebung

Mit Windows PowerShell ISE steht neben dem reinen Command Line Interface auch ein leistungsfähiger Skripteditor und Debugger zur Verfügung. Auch Windows PowerShell ISE ist in der Regel im Lieferumfang von Windows enthalten. Die Abkürzung ISE steht für "Integrated Scripting Environment" (integrierte Skript-Umgebung).

Dank des in der Umgebung integrierten Editors vereinfacht sich die Bearbeitung und das Erstellen von Skripten erheblich. Schlüsselwörter werden hervorgehoben und Befehle oder Dateinamen durch Drücken der Tabulatortaste wie im normalen PowerShell-CLI vervollständigt. Neben dem Eingabefenster für die Befehle ist eine ausführliche Befehlsübersicht und -dokumentation in einem zusätzlichen Fenster enthalten. Über die Debug-Funktionen ist es möglich, Haltepunkte zu setzen und Skripte Schritt für Schritt auszuführen und zu analysieren. Auch den Inhalt von Variablen zeigt der Debugger bei Bedarf an. Über so genannte Add-ons kann der ISE fast beliebig erweitert werden.

Kommentare werden geladen....

Kommentar zu diesem Artikel

Anonym mitdiskutieren oder einloggen Anmelden

Avatar
  1. Avatar
    Avatar
    Bearbeitet von am
    Bearbeitet von am
    1. Avatar
      Avatar
      Bearbeitet von am
      Bearbeitet von am

Kommentare werden geladen....

Kommentar melden

Melden Sie diesen Kommentar, wenn dieser nicht den Richtlinien entspricht.

Kommentar Freigeben

Der untenstehende Text wird an den Kommentator gesendet, falls dieser eine Email-hinterlegt hat.

Freigabe entfernen

Der untenstehende Text wird an den Kommentator gesendet, falls dieser eine Email-hinterlegt hat.

Aktuelle Beiträge zu diesem Thema

10 Mythen über den Einsatz von Windows-Servern

Microsoft Windows Server sind besser als ihr Ruf

10 Mythen über den Einsatz von Windows-Servern

Geht es um den Einsatz von Windows-Servern, grassieren in Administrator-Kreisen insbesondere in puncto Sicherheit, Usability, Zuverlässigkeit und Kompatibilität viele Halbwahrheiten. Wir beleuchten 10 der am häufigsten genannten Mythen und erkunden deren Wahrheitsgehalt. lesen

7 Gründe gegen den Einsatz eines Nano-Servers

Die Nano-Server-Edition von Windows Server 2016 in der Kritik

7 Gründe gegen den Einsatz eines Nano-Servers

Mit Windows Server 2016 hat Microsoft auch die neuen Nano-Server vorgestellt. Die sind kleiner und sollen effizienter sein als herkömmliche Windows-Server. Doch nicht immer ist ihr Einsatz sinnvoll und Nano-Server sind längst kein Königsweg, wenn es um die Sicherheit geht. Sieben Argumente, wann und warum der Einsatz von Nano-Servern nicht sinnvoll ist. lesen

In 14 Schritten zum perfekten Domänencontroller

Wege zum stabilen und schnellen Active Directory

In 14 Schritten zum perfekten Domänencontroller

Active Directory ist in Windows-Netzwerken essentielle Grundlage für einen stabilen Betrieb. Damit das AD optimal funktioniert, sollten Administratoren bei der Installation der Domäne und der Domänencontroller besonders umsichtig vorgehen. Wir zeigen die 14 wichtigsten Schritte beim Installieren neuer Domänencontroller auf Basis von Windows Server 2012 R2 und Server 2016. lesen

Windows Server 2016 Insider Previews nutzen

Hyper-V, Container, Nano-Server und mehr

Windows Server 2016 Insider Previews nutzen

Microsoft bietet für Windows Server 2016 neue Insider Previews, die neue Funktionen in das Server-Betriebssystem integrieren. Wir zeigen die wichtigsten Neuerungen und deren Vorteile. Die Vorabversionen sind natürlich nicht für den Produktivbetrieb geeignet. lesen

5 Herausforderungen in hybriden Active Directory-Umgebungen

Identity & Access Management in AD und AAD

5 Herausforderungen in hybriden Active Directory-Umgebungen

Fast 90 Prozent aller Unternehmen weltweit setzen Active Directory als On-Premises-Variante ein. In der Welt des Identity und Access Managements (IAM) ist AD heute so allgegenwärtig wie notwendig und Azure Active Directory, der Cloud-basierte Bruder, gewinnt zunehmend an Bedeutung. lesen

Vollautomatische Kontrolle der IT-Infrastruktur

AppSphere und Paessler kooperieren

Vollautomatische Kontrolle der IT-Infrastruktur

Der PRTG Network Monitor kann ab sofort in die ScriptRunner Automation & Delegation Suite for PowerShell integriert werden. Das Ergebnis, so die Hersteller Paessler und AppSphere: die automatisierte Verwaltung und Problemlösung in Sachen IT-Infrastruktur für Admins und DevOps. lesen

Sichere Benutzerkonten in Windows Server 2016

Just-In-Time-Administration (JIT)

Sichere Benutzerkonten in Windows Server 2016

Mit Privileged Account Management (PAM), Just-In-Time-Administration (JIT) und Just Enough Administration (JEA) können Unternehmen unter Windows Server 2016 sicherstellen, dass die Administratorkonten nicht für Angriffe auf das Netzwerk verwendet werden können, und nur die notwendigen Sicherheitsberechtigungen genau für den Zeitpunkt erhalten, der notwendig ist. lesen

5 Schritte zur sicheren Active Directory-Umgebung

Mehr Sicherheit für Domänencontroller

5 Schritte zur sicheren Active Directory-Umgebung

Das Active Directory wird in vielen Unternehmen als zentrales Element zur Authentifizierung genutzt. Daher stehen die Domänencontroller auch im Fokus von Angreifern. Werden diese Systeme kompromittiert, dann ist oft das gesamte Netzwerk in Gefahr. Mit Bordmitteln lässt sich die Sicherheit aber deutlich erhöhen. lesen

Unified-Monitoring: kleines Team mit großem Überblick

Bauer Gruppe setzt beim Infrastruktur-Monitoring auf PRTG

Unified-Monitoring: kleines Team mit großem Überblick

Die Bauer Gruppe verfügt als internationales Bau- und Maschinenbauunternehmen über zahlreiche Niederlassungen weltweit. Ein kleines Team überwacht zentral im bayerischen Schrobenhausen sämtliche Zweigstellen mitsamt ihren IT- und Non-IT-Komponenten. Diese technische Herausforderung meistert die Bauer Gruppe seit Kurzem mit Hilfe der IT-Monitoring-Software PRTG Network Monitor von Paessler. lesen

copyright

Dieser Beitrag ist urheberrechtlich geschützt. Sie wollen ihn für Ihre Zwecke verwenden? Infos finden Sie unter www.mycontentfactory.de (ID: 44959925 / Definitionen)