Herstellen einer Verbindung mit einem sicheren Dienst mit dem Reverseproxy

In diesem Artikel wird erläutert, wie eine sichere Verbindung zwischen dem Reverseproxy und Diensten hergestellt und so ein sicherer End-to-End-Kanal ermöglicht wird. Weitere Informationen zum Reverseproxy finden Sie unter Reverseproxy in Azure Service Fabric.

Wichtig

Die Herstellung einer Verbindung mit sicheren Diensten wird nur unterstützt, wenn der Reverseproxy für das Lauschen von HTTPS konfiguriert ist. In diesem Artikel wird davon ausgegangen, dass dies der Fall ist. Informationen zum Konfigurieren des Reverseproxys in Service Fabric finden Sie unter Setup reverse proxy in Azure Service Fabric (Reverseproxy-Setup in Azure Service Fabric).

Herstellung einer sicheren Verbindung zwischen dem Reverseproxy und Diensten

Reverseproxy authentifiziert sich bei Diensten:

Der Reverseproxy identifiziert sich bei Diensten selbst über sein Zertifikat. Für Azure-Cluster wird das Zertifikat mit der reverseProxyCertificate-Eigenschaft im RessourcentypenabschnittMicrosoft.ServiceFabric/clusters der Resource Manager-Vorlage angegeben. Für eigenständige Cluster wird das Zertifikat entweder mit der Eigenschaft ReverseProxyCertificate oder ReverseProxyCertificateCommonNames im Abschnitt Security (Sicherheit) der Datei „ClusterConfig.json“ angegeben. Weitere Informationen finden Sie unter Aktivieren des Reverseproxys auf eigenständigen Clustern.

Die Dienste können die Logik implementieren, um das vom Reverseproxy bereitgestellte Zertifikat zu überprüfen. Die Dienste können die Details des akzeptierten Clientzertifikats als Konfigurationseinstellungen im Konfigurationspaket angeben. Dieses kann zur Laufzeit gelesen und zum Überprüfen des vom Reverseproxy bereitgestellten Zertifikats verwendet werden. Informationen zum Hinzufügen der Konfigurationseinstellungen finden Sie unter Verwalten von Anwendungsparametern.

Reverseproxy überprüft die Identität des Diensts über das vom Dienst bereitgestellte Zertifikat:

Der Reverseproxy unterstützt für die Ausführung der Serverzertifikatüberprüfung der von den Diensten bereitgestellten Zertifikate die folgenden Richtlinien: „Keine“ (None), „ServiceCommonNameAndIssuer“ und „ServiceCertificateThumbprints“. Um die vom Reverseproxy zu verwendende Richtlinie auszuwählen, geben Sie ApplicationCertificateValidationPolicy im Abschnitt ApplicationGateway/Http unter fabricSettings an.

Der nächste Abschnitt enthält die Konfigurationsdetails für die einzelnen Optionen.

Optionen für die Dienstzertifikatüberprüfung

  • Keine: Der Reverseproxy überspringt die Überprüfung des an den Proxy übermittelten Dienstzertifikats und stellt die sichere Verbindung her. Dies ist das Standardverhalten. Geben Sie ApplicationCertificateValidationPolicy mit dem Wert None im Abschnitt ApplicationGateway/Http ein.

    {
    "fabricSettings": [
               ...
               {
                 "name": "ApplicationGateway/Http",
                 "parameters": [
                   {
                     "name": "ApplicationCertificateValidationPolicy",
                     "value": "None"
                   }
                 ]
               }
             ],
             ...
    }
    
  • ServiceCommonNameAndIssuer: Der Reverseproxy überprüft das vom Dienst bereitgestellte Zertifikat anhand des allgemeinen Namens des Zertifikats und des Fingerabdrucks des unmittelbaren Ausstellers: Geben Sie ApplicationCertificateValidationPolicy mit dem Wert ServiceCommonNameAndIssuer im Abschnitt ApplicationGateway/Http an.

    {
    "fabricSettings": [
               ...
               {
                 "name": "ApplicationGateway/Http",
                 "parameters": [
                   {
                     "name": "ApplicationCertificateValidationPolicy",
                     "value": "ServiceCommonNameAndIssuer"
                   }
                 ]
               }
             ],
             ...
    }
    

    Um die Liste der allgemeinen Namen des Diensts und der Fingerabdrücke des Ausstellers anzugeben, fügen Sie wie weiter unten dargestellt einen ApplicationGateway/Http/ServiceCommonNameAndIssuer-Abschnitt unter fabricSettings ein. Im Array parameters können mehrere Paare von allgemeinen Namen des Zertifikats und Fingerabdrücken des Ausstellers hinzugefügt werden.

    Wenn der Endpunkt, mit dem der Reverseproxy eine Verbindung herstellt, ein Zertifikat bereitstellt, dessen allgemeiner Name und Fingerabdruck des Ausstellers mit einem der hier angegebenen Werte übereinstimmt, wird der TLS-Kanal eingerichtet. Bei Nichtübereinstimmung der Zertifikatdetails gibt der Reverseproxy für die Anforderung des Clients eine Fehlermeldung mit dem Statuscode 502 (Ungültiges Gateway) aus. Zudem enthält die HTTP-Statuszeile den Ausdruck „Invalid SSL Certificate“.

    {
    "fabricSettings": [
               ...
               {
                 "name": "ApplicationGateway/Http/ServiceCommonNameAndIssuer",
                 "parameters": [
                   {
                     "name": "WinFabric-Test-Certificate-CN1",
                     "value": "b3 44 9b 01 8d 0f 68 39 a2 c5 d6 2b 5b 6c 6a c8 22 b4 22 11"
                   },
                   {
                     "name": "WinFabric-Test-Certificate-CN2",
                     "value": "b3 44 9b 01 8d 0f 68 39 a2 c5 d6 2b 5b 6c 6a c8 22 11 33 44"
                   }
                 ]
               }
             ],
             ...
    }
    
  • ServiceCertificateThumbprints: Der Reverseproxy überprüft das an den Proxy übermittelte Dienstzertifikat anhand des zugehörigen Fingerabdrucks. Diese Option können Sie auswählen, wenn die Dienste mit selbstsignierten Zertifikaten konfiguriert sind: Geben Sie ApplicationCertificateValidationPolicy mit dem Wert ServiceCertificateThumbprints im Abschnitt ApplicationGateway/Http an.

    {
    "fabricSettings": [
               ...
               {
                 "name": "ApplicationGateway/Http",
                 "parameters": [
                   {
                     "name": "ApplicationCertificateValidationPolicy",
                     "value": "ServiceCertificateThumbprints"
                   }
                 ]
               }
             ],
             ...
    }
    

    Geben Sie zudem die Fingerabdrücke mit einem ServiceCertificateThumbprints-Eintrag im Abschnitt ApplicationGateway/Http an. Mehrere Fingerabdrücke können, wie im Folgenden dargestellt, als eine durch Trennzeichen getrennte Liste im Wertfeld angegeben werden:

    {
    "fabricSettings": [
               ...
               {
                 "name": "ApplicationGateway/Http",
                 "parameters": [
                     ...
                   {
                     "name": "ServiceCertificateThumbprints",
                     "value": "78 12 20 5a 39 d2 23 76 da a0 37 f0 5a ed e3 60 1a 7e 64 bf,78 12 20 5a 39 d2 23 76 da a0 37 f0 5a ed e3 60 1a 7e 64 b9"
                   }
                 ]
               }
             ],
             ...
    }
    

    Wenn der Fingerabdruck des Serverzertifikats in diesem Konfigurationseintrag aufgeführt ist, stellt der Reverseproxy die TLS-Verbindung her. Andernfalls beendet er die Verbindung und gibt für die Anforderung des Clients eine Fehlermeldung mit dem Statuscode 502 (Ungültiges Gateway) aus. Zudem enthält die HTTP-Statuszeile den Ausdruck „Invalid SSL Certificate“.

Logik der Endpunktauswahl, wenn Dienste sichere und nicht sichere Endpunkte bereitstellen

Service Fabric unterstützt die Konfiguration mehrerer Endpunkte für einen Dienst. Weitere Informationen finden Sie unter Angeben von Ressourcen in einem Dienstmanifest.

Der Reverseproxy wählt einen der Endpunkte zum Weiterleiten der Anforderung basierend auf dem Abfrageparameter ListenerName im Dienst-URI aus. Wird der Parameter ListenerName nicht angegeben, kann der Reverseproxy einen beliebigen Endpunkt in der Liste der Endpunkte auswählen. Abhängig von den für den Dienst konfigurierten Endpunkten kann der ausgewählte Endpunkt ein HTTP- oder ein HTTPS-Endpunkt sein. Unter Umständen gibt es Szenarien oder Anforderungen, bei denen der Reverseproxy im „ausschließlich sicheren Modus“ ausgeführt werden soll. Das bedeutet, dass der sichere Reverseproxy keine Anforderungen an nicht sichere Endpunkte weiterleiten soll. Um für den Reverseproxy den ausschließlich sicheren Modus festzulegen, geben Sie den Konfigurationseintrag SecureOnlyMode im Abschnitt ApplicationGateway/Http mit dem Wert true an.

{
"fabricSettings": [
          ...
          {
            "name": "ApplicationGateway/Http",
            "parameters": [
                ...
              {
                "name": "SecureOnlyMode",
                "value": true
              }
            ]
          }
        ],
        ...
}

Hinweis

Wenn im SecureOnlyMode der Client ein ListenerName-Element angegeben hat, das einem HTTP-Endpunkt (ungesichert) entspricht, gibt der Reverseproxy für die Anforderung eine Fehlermeldung mit dem HTTP-Statuscode 404 (Nicht gefunden) aus.

Einrichten der Clientzertifikatauthentifizierung über den Reverseproxy

Die TLS-Terminierung erfolgt auf dem Reverseproxy, und alle Daten des Clientzertifikats gehen verloren. Damit die Dienste die Clientzertifikatauthentifizierung durchführen, legen Sie die Einstellung ForwardClientCertificate im Abschnitt ApplicationGateway/Http fest.

  1. Wenn ForwardClientCertificate auf false festgelegt ist, fordert der Reverseproxy das Clientzertifikat während des TLS-Handshakes mit dem Client nicht an. Dies ist das Standardverhalten.

  2. Wenn ForwardClientCertificate auf true festgelegt ist, fordert der Reverseproxy das Clientzertifikat während des TLS-Handshakes mit dem Client an. Dann leitet er die Daten des Clientzertifikats in einem benutzerdefinierten HTTP-Header mit dem Namen X-Client-Certificate weiter. Der Headerwert ist die Base64-codierte Zeichenfolge im PEM-Format des Clientzertifikats. Der Dienst kann die Anforderung nach dem Überprüfen der Zertifikatdaten mit dem entsprechenden Statuscode annehmen oder ablehnen. Wenn der Client kein Zertifikat bereitstellt, leitet der Reverseproxy einen leeren Header weiter. Die weitere Verarbeitung erfolgt durch den Dienst.

Hinweis

Der Reverseproxy fungiert nur als Weiterleitungsdienst. Er führt keine Überprüfung des Clientzertifikats durch.

Nächste Schritte