Auf dieser Seite wird beschrieben, wie Sie die TLS-Prüfung (Transport Layer Security) für Ihre Secure Web Proxy-Instanz aktivieren.
Hinweise
Bevor Sie Secure Web Proxy für die TLS-Prüfung konfigurieren, führen Sie die Aufgaben in den folgenden Abschnitten aus.
CAS aktivieren
Secure Web Proxy verwendet den CAS (Certificate Authority Service), um die für die TLS-Prüfung verwendeten Zertifikate zu generieren.
Verwenden Sie den folgenden Befehl, um CAS zu aktivieren:
gcloud services enable privateca.googleapis.com
CA-Pool erstellen
Sie müssen einen CA-Pool erstellen, bevor Sie CAS zum Erstellen einer CA verwenden können. In diesem Abschnitt werden die Berechtigungen beschrieben, die Sie für diese Aufgabe benötigen. Anschließend wird beschrieben, wie Sie einen CA-Pool erstellen.
Für die Generierung von Zertifikaten verwendet die TLS-Prüfung für jedes Projekt ein separates Dienstkonto namens service-{project ID}@gcp-sa-certmanager.iam.gserviceaccount.com
.
Achten Sie darauf, dass Sie diesem Dienstkonto die Berechtigung zur Verwendung Ihres CA-Pools erteilt haben. Wenn dieser Zugriff widerrufen wird, funktioniert die TLS-Prüfung nicht mehr.
Verwenden Sie den Befehl gcloud privateca pools create
, um den Pool zu erstellen, und geben Sie die untergeordnete Pool-ID, die Stufe, die Projekt-ID und den Speicherort an.
gcloud privateca pools create SUBORDINATE_POOL_ID \ --tier=TIER \ --project=PROJECT_ID \ --location=REGION
Ersetzen Sie Folgendes:
SUBORDINATE_POOL_ID
: der Name des CA-PoolsTIER
: die Zertifizierungsstellenebene, entwederdevops
oderenterprise
Wir empfehlen, den CA-Pool in der Ebene
devops
zu erstellen, da das Nachverfolgen einzeln ausgestellter Zertifikate nicht erforderlich ist.PROJECT_ID
: die ID des CA-Pool-ProjektsREGION
: der Standort des CA-Pools
Untergeordneten CA-Pool erstellen
Sie können einen untergeordneten CA-Pool erstellen und die Stamm-CA signiert alle CAs in diesem Pool. Diese Zertifikate werden verwendet, um Serverzertifikate zu signieren, die für die TLS-Prüfung generiert wurden.
Sie haben mehrere Möglichkeiten, einen untergeordneten Pool zu erstellen.
Einen untergeordneten CA-Pool mit einer vorhandenen Root-CA erstellen, die in CAS gespeichert ist
So generieren Sie eine untergeordnete Zertifizierungsstelle:
Untergeordneten CA-Pool mit einer externen Stamm-CA erstellen
So generieren Sie eine untergeordnete Zertifizierungsstelle:
- Erstellen Sie einen CA-Pool.
- Erstellen Sie untergeordnete Zertifizierungsstellen, die von einer externen Stamm-CA signiert wurden.
Stamm-CA erstellen
Wenn Sie keine vorhandene Stamm-CA haben, können Sie in CAS eine erstellen. So erstellen Sie eine Root-CA:
- Erstellen Sie eine Stamm-CA.
- Folgen Sie der Anleitung unter Untergeordneten CA-Pool mit einer vorhandenen Stamm-CA erstellen, die in CAS gespeichert ist.
Weitere Informationen zu CA-Pools finden Sie in der Dokumentation zum Certificate Authority Service.
Dienstkonto erstellen
Wenn Sie kein Dienstkonto haben, müssen Sie eines erstellen und die erforderlichen Berechtigungen erteilen.
Erstellen Sie ein Dienstkonto:
gcloud beta services identity create \ --service=networksecurity.googleapis.com \ --project=PROJECT_ID
Daraufhin erstellt die Google Cloud CLI ein Dienstkonto mit dem Namen
service-{project ID}@gcp-sa-networksecurity.iam.gserviceaccount.com
.Gewähren Sie dem von Ihnen erstellten Dienstkonto die Berechtigung, Zertifikate mit Ihrem CA-Pool zu generieren:
gcloud privateca pools add-iam-policy-binding CA_POOL \ --member='serviceAccount:SERVICE_ACCOUNT' \ --role='roles/privateca.certificateManager' \ --location='REGION'
Secure Web Proxy für die TLS-Prüfung konfigurieren
Sie können mit den Aufgaben in diesem Abschnitt erst fortfahren, wenn Sie die im Abschnitt Vorbereitung aufgeführten Voraussetzungen erfüllt haben.
Führen Sie die Aufgaben in den folgenden Abschnitten aus, um die TLS-Prüfung zu konfigurieren.
TLS-Prüfungsrichtlinie erstellen
Erstellen Sie die Datei
TLS_INSPECTION_FILE
.yaml. Ersetzen SieTLS_INSPECTION_FILE
durch den gewünschten Dateinamen.Fügen Sie der YAML-Datei den folgenden Code hinzu, um die gewünschte TlsInspectionPolicy zu konfigurieren:
name: projects/PROJECT_ID/locations/REGION/tlsInspectionPolicies/TLS_INSPECTION_NAME caPool: projects/PROJECT_ID/locations/REGION/caPools/CA_POOL
Ersetzen Sie Folgendes:
PROJECT_ID
: die ProjektnummerREGION
: die Region, in der die Richtlinie erstellt werden sollTLS_INSPECTION_NAME
: der Name der TLS-Prüfungsrichtlinie für den Secure Web ProxyCA_POOL
: der Name des CA-Pools, aus dem die Zertifikate erstellt werden sollenDer CA-Pool muss in derselben Region vorhanden sein.
TLS-Prüfungsrichtlinie importieren
Importieren Sie die TLS-Prüfungsrichtlinie, die Sie im vorherigen Schritt erstellt haben:
gcloud network-security tls-inspection-policies import TLS_INSPECTION_NAME \
--source=TLS_INSPECTION_FILE.yaml \
--location=REGION
TLS-Prüfungsrichtlinie zur Sicherheitsrichtlinie hinzufügen
Console
Web-Proxy-Richtlinie erstellen
Rufen Sie in der Google Cloud Console die Seite Netzwerksicherheit auf.
Klicken Sie auf Sicherer Web-Proxy.
Klicken Sie auf den Tab Richtlinien.
Klicken Sie auf Richtlinie erstellen.
Geben Sie einen Namen für die Richtlinie ein, die Sie erstellen möchten, z. B.
myswppolicy
.Geben Sie eine Beschreibung der Richtlinie ein, z. B.
My new swp policy
.Wählen Sie in der Liste Regionen die Region aus, in der Sie die Richtlinie für den sicheren Webproxy erstellen möchten.
Wählen Sie TLS-Prüfung konfigurieren aus, um die TLS-Prüfung zu konfigurieren.
Wählen Sie in der Liste TLS-Prüfungsrichtlinie die von Ihnen erstellte TLS-Prüfungsrichtlinie aus.
Wenn Sie Regeln für die Richtlinie erstellen möchten, klicken Sie auf Weiter und dann auf Regel hinzufügen. Weitere Informationen finden Sie unter Regeln für sicheren Webproxy erstellen.
Klicken Sie auf Erstellen.
Web-Proxy-Regeln erstellen
Rufen Sie in der Google Cloud Console die Seite Netzwerksicherheit auf.
Klicken Sie auf Sicherer Web-Proxy.
Wählen Sie im Menü „Projektauswahl“ Ihre Organisations-ID oder den Ordner aus, der die Richtlinie enthält.
Klicken Sie auf den Namen Ihrer Richtlinie.
Klicken Sie auf Regel hinzufügen.
Füllen Sie die Regelfelder aus:
- Name
- Beschreibung
- Status
- Priorität: die numerische Auswertungsreihenfolge der Regel. Die Regeln werden von der höchsten bis zur niedrigsten Priorität ausgewertet, wobei
0
die höchste Priorität ist. - Geben Sie im Abschnitt Aktion an, ob Verbindungen, die der Regel entsprechen, zugelassen (Zulassen) oder abgelehnt (Ablehnen) werden sollen.
- Geben Sie im Bereich Sitzungsabgleich die Kriterien für den Sitzungsabgleich an. Weitere Informationen zur Syntax für
SessionMatcher
finden Sie in der Referenz zur CEL-Abgleichssprache. - Wählen Sie TLS-Prüfung aktivieren aus, um die TLS-Prüfung zu aktivieren.
- Geben Sie im Abschnitt Anwendungsabgleich die Kriterien für den Abgleich der Anfrage an. Wenn Sie die Regel für die TLS-Prüfung nicht aktivieren, kann die Anfrage nur mit HTTP-Traffic abgeglichen werden.
- Klicken Sie auf Erstellen.
Klicken Sie auf Regel hinzufügen, um eine weitere Regel hinzuzufügen.
Klicken Sie auf Erstellen, um die Richtlinie zu erstellen.
Web-Proxy einrichten
Rufen Sie in der Google Cloud Console die Seite Netzwerksicherheit auf.
Klicken Sie auf Sicherer Web-Proxy.
Klicken Sie auf den Tab Webproxys.
Klicken Sie auf Webproxy einrichten.
Geben Sie einen Namen für den Webproxy ein, den Sie erstellen möchten, z. B.
myswp
.Geben Sie eine Beschreibung des Web-Proxys ein, z. B.
My new swp
.Wählen Sie in der Liste Regionen die Region aus, in der Sie den Webproxy erstellen möchten.
Wählen Sie in der Liste Netzwerk das Netzwerk aus, in dem Sie den Webproxy erstellen möchten.
Wählen Sie in der Liste Subnetzwerk das Subnetzwerk aus, in dem Sie den Webproxy erstellen möchten.
Geben Sie die IP-Adresse des Webproxys ein.
Wählen Sie in der Liste Zertifikat das Zertifikat aus, mit dem Sie den Webproxy erstellen möchten.
Wählen Sie in der Liste Richtlinie die Richtlinie aus, die Sie erstellt haben, um den Webproxy zu verknüpfen.
Klicken Sie auf Erstellen.
Cloud Shell
Erstellen Sie die Datei
policy.yaml
:description: basic Secure Web Proxy policy name: projects/PROJECT_ID/locations/REGION/gatewaySecurityPolicies/policy1 tlsInspectionPolicy: projects/PROJECT_ID/locations/REGION/tlsInspectionPolicies/TLS_INSPECTION_NAME
Erstellen Sie die Secure Web Proxy-Richtlinie:
gcloud network-security gateway-security-policies import policy1 \ --source=policy.yaml --location=REGION
Erstellen Sie die Datei
rule.yaml
:name: projects/PROJECT_ID/locations/REGION/gatewaySecurityPolicies/policy1/rules/allow-example-com description: Allow example.com enabled: true priority: 1 basicProfile: ALLOW sessionMatcher: host() == 'example.com' applicationMatcher: request.path.contains('index.html') tlsInspectionEnabled: true
Erstellen Sie die Sicherheitsrichtlinienregel:
gcloud network-security gateway-security-policies rules import allow-example-com \ --source=rule.yaml \ --location=REGION \ --gateway-security-policy=policy1
Wenn Sie einer vorhandenen Sicherheitsrichtlinie eine TLS-Prüfungsrichtlinie zuordnen möchten, erstellen Sie die Datei
POLICY_FILE
.yaml. Ersetzen SiePOLICY_FILE
durch den gewünschten Dateinamen.description: My Secure Web Proxy policy name: projects/PROJECT_ID/locations/REGION/gatewaySecurityPolicies/POLICY_NAME tlsInspectionPolicy: projects/PROJECT_ID/locations/REGION/tlsInspectionPolicies/TLS_INSPECTION_NAME