VMware-Verschlüsselung: Key Management Server (KMS) einrichten


    Tags: ,

    Virtuelle Maschinen verschlüsselnDie Verschlüsselung von VMs "in transit" (vMotion) und "at rest" erfordert keine Ver­schlüsselungs­soft­ware in den VMs. Im gesamten Work­flow lan­den auf ESXi-Hosts oder Data­stores somit keine Schlüssel, die kompro­mittiert werden könnten. Dafür muss der Nutzer aber einen Key Management Server (KMS) betreiben.

    Die von VMware mit vSphere 6.5 eingeführte VM-Verschlüsselungs­architektur besteht aus drei Komponenten:

    1. Ein KMS ist ein externer Server, der Schlüssel für Dienste generiert und von einem Sicherheits­anbieter bereitgestellt wird.
    2. Der vCenter-Server kommuniziert mit einem KMS und fordert Schlüssel im Namen der ESXi-Hosts an.
    3. ESXi-Hosts führen verschlüsselte VMs aus.

    Insgesamt sind drei Arten von Schlüsseln in den Prozess involviert:

    • Host-Keys sorgen dafür, dass Hosts krypto­grafisch sicher sind. Sie werden im Memory-Key-Cache eines im krypto­grafischen Modus betriebenen ESXi abgelegt. Um einen Host in den Verschlüsselungs­modus zu bringen, fordert vCenter beim erstmaligen Auftreten einer Ver­schlüsselungs­operation einen Key vom KMS an und sendet diesen an jeden Host im Cluster. Der Host installiert ihn dann im Memory-Key-Cache und aktiviert die Core-Dump-Verschlüsselung.
    • Der vCenter-Server fordert auch die VM-Keys vom KMS an und leitet sie an die Hosts bzw. Cluster weiter, ohne sie selbst zu speichern. Er merkt sich nur die jeweilige Key-ID. VM-Keys werden auch als Schlüssel­verschlüsselungs­schlüssel (KEK) bezeichnet.
      Dieser Schlüssel verbleibt bis zum Neustart eines Hosts im ESXi-Speicher, weshalb im Falle eines Systemabsturzes der jeweilige Core-Dump mit Hilfe des Host-Keys verschlüsselt wird. VM-Keys sind symmetrische AES-256-Schlüssel.
    • Den für jede kryptografische Operation benötigten Daten­verschlüsselungs­schlüssel (DEK), mit dem die virtuellen Maschinen nebst ihrer Festplatten kodiert werden, generiert jeder Hosts selbst. Er speichert den DEK, den er mit dem KEK verschlüsselt, im vmx-File der jeweiligen VM. Bei den Data Encryption Keys handelt es sich um symmetrische XTS-AES-256-Schlüssel.

    Unterstützte KMS

    Um die gesamte Umgebung für die Verschlüsselung virtueller Maschinen vorzubereiten, führt also kein Weg daran vorbei, einen KMS einrichten. Zulässige Systeme finden sich in der HCL. Das Portfolio ist dabei in den letzten Jahren deutlich erweitert worden.

    Der Compatibility Guide von VMware gibt Auskunft über die unterstützten Key Management Server.

    Unterstützt werden zum Beispiel Dell Cloud Link, Fujitsu Eternus SF KM, Gemalto SafeNet Key Secure, HyTrust KeyControl, IBM Security Key Lifecycle Manager, Thales eSecurity Vormetric Data Security Manager, Townsend Security Alliance Key Manager, Ultimaco ESKM oder Zettaset Key Manager.

    KMIP und KMS

    Der verwendete KMS muss mit KMIP 1.1 kompatibel sein. Hierbei handelt es sich um eine Standardsprache für die Verwaltung von Sicherheits­schlüsseln. Ein standard­konformer KMS bietet einen Schlüssel­verwaltungs­dienst für KMIP-Clients wie vCenter und kann mit einem KMIP-Proxy-Server konfiguriert werden.

    Auf den mit KMIP 1.1 kompatiblen KMS wird in der Regel mittels IPv4 zugegriffen. Größeren Unter­nehmen empfiehlt VMware, den Service ausfallsicher in einem Cluster aus KMIP-basierten Schlüssel­verwaltungs-Servern zu betreiben, welche die Keys untereinander replizieren.

    Kommunikation absichern

    Der vCenter-Server speichert die KMS-Anmelde­informationen und verwaltet die zur Verschlüsselung verwendeten Keys anhand der UUID. Ferner ruft das vCenter bei Bedarf Schlüssel vom KMS ab und übergibt sie an die ESXi-Hosts.

    Um die Kommunikation zwischen dem KMIP-Server (KMS) und dem KMIP-Client (vCenter-Server) zu sichern, muss eine Vertrauens­stellung eingerichtet werden. VCenter Server 6.7 verwendet TLS 1.2 für die Kommunikation mit dem KMS.

    Der vom KMIP-Client verwendete Zertifikatstyp hängt vom KMS-Anbieter ab. Nicht alle akzeptieren selbst erstellte Zertifikate. Bei einigen Produkten generiert der KMS ein vertrauens­würdiges Zertifikat für den Client, das dieser herunterladen muss. Andere Anbieter akzeptieren nur ein vom KMS selbst bereitgestelltes Client-Zertifikat.

    Core-Dumps und kryptografischer Modus

    Bei der Verschlüsselung von Core-Dumps kommt ein Envelope-Verfahren zum Einsatz: Dazu generiert der Host zunächst einen internen Einmalschlüssel (AES-256) und legt dann den Core Dump in einen digitalen Umschlag.

    Der Umschlag und der Core Dump werden mit diesem internen Schlüssel verschlüsselt. Der interne Schlüssel wird dann mit dem Host-Schlüssel kodiert und dann als Teil des Umschlags gespeichert.

    Um den Inhalt der Core-Dump-Datei anzuzeigen, muss man den Umschlag mit dem Host-Schlüssel öffnen. Da dieser nur auf dem Host verfügbar ist, kann der technische Support von VMware nicht auf den Core-Dump zugreifen, um das Debuggen eines System­absturzes zu unterstützen. Mit dem CLI-Befehl crypto-util können Core-Dumps aber vom Nutzer ver- und entschlüsselt werden.

    Täglich Know-how für IT-Pros mit unserem Newsletter

    Wir ver­wenden Ihre Mail-Adresse nur für den Ver­sand der News­letter.
    Es erfolgt keine per­sonen­be­zogene Auswertung.

    Bild von Thomas Drilling

    Thomas Drilling arbeitet ist seit fast 30 Jahren selb­ständig in der IT-Welt sowohl als Consultant, als auch als Redakteur, Buchautor und Journalist für viele ehe­malige und aktuelle IT-Magazine sowie Blogs.

    Aktuell bestätigt sich Thomas schwerpunktmäßig als IT-Trainer für Cloud-Computing in den Bereichen Microsoft Azure, Amazon Web Services und VMware.

    Thomas ist zertifizierter Microsoft-Trainer für nahe das gesamte Portfolio an Microsoft Azure Trainings. Thomas ist außerdem zerti­fi­zierter Microsoft Azure Solutions Architect Expert sowie VMware Certified Professional und wurde von VMware in den Jahren 2016 bis 2022 mit dem Blogger-Status vExpert ausge­zeichnet.

    Thomas führt aktuell jeden Monat zwei selbstkonziperte 4-tägigen Grund­lagenkurse in Cloud Computing mit Azure durch, die sich inhaltlich bewusst von den Microsft-Kursen abheben und vorzuweise als Bootcamp in eine besonderen Lokation stattfinden. Optional kann aber aber auch remote via Microsoft Teams teilgenommen werden.

    Das aktuelle Trainingsprogramm findet sich unter Azure-Trainings. Weitere Infor­mationen und Anmel­dung über sein Azure-Blog.

    Verwandte Beiträge

    Weitere Links