IP-Adressen und Ports
Auf dieser Seite wird beschrieben, wie Cloud NAT-Gateways IP-Adressen verwenden und Quellports zu VM-Instanzen von Compute Engine und GKE-Knoten (Google Kubernetes Engine) zuweisen, die die Gateways verwenden.
Bevor Sie diese Informationen lesen, machen Sie sich mit der Cloud NAT-Übersicht vertraut.
Öffentliche NAT-IP-Adressen
Eine öffentliche NAT-IP-Adresse ist eine regionale externe IP-Adresse, die über das Internet weitergeleitet werden kann. Eine VM ohne externe IP-Adresse in einem Subnetzwerk (Subnetz), das von einem öffentlichen NAT-Gateway bereitgestellt wird, verwendet eine öffentliche NAT-IP-Adresse, wenn sie Pakete an ein Ziel im Internet sendet.
Verwenden Sie eine der folgenden Methoden, um einem öffentlichen NAT-Gateway NAT-IP-Adressen zuzuweisen:
Automatische NAT-IP-Adresszuweisung: Wenn Sie diese Methode oder die Google Cloud-Standardeinstellungen auswählen, fügt Public NAT Ihrem Gateway basierend auf den folgenden Kriterien automatisch regionale externe IP-Adressen hinzu:
- Die von Ihnen ausgewählte Netzwerkebene
- Die Anzahl der VMs, die das Gateway verwenden
- Die Anzahl der Ports, die für jede VM reserviert sind
Außerdem wird bei Public NAT automatisch eine NAT-IP-Adresse entfernt, wenn keine Quellports mehr an dieser NAT-IP-Adresse benötigt werden.
Die automatische NAT-IP-Adresszuweisung hat folgende Merkmale:
Wenn ein öffentliches NAT-Gateway eine NAT-IP-Adresse hinzufügt, wird eine statische (reservierte) regionale externe IP-Adresse in der Netzwerkebene erstellt, die Sie beim Konfigurieren des Gateways ausgewählt haben. Wenn Sie beispielsweise die Premium-Stufe ausgewählt haben, erstellt das öffentliche NAT-Gateway die IP-Adresse in dieser Stufe. Die unterstützten Netzwerkstufen sind die Premium-Stufe (Standardoption) und die Standardstufe.
Die automatisch hinzugefügten NAT-IP-Adressen finden Sie in der Liste der statischen externen IP-Adressen. Diese Adressen werden nicht auf Projektkontingente angerechnet.
- Wenn Sie die Netzwerkebene eines öffentlichen NAT-Gateways ändern, werden die vorhandenen IP-Adressen für dieses Gateway freigegeben und eine neue Gruppe von IP-Adressen aus der ausgewählten Ebene wird zugewiesen.
- Mit der automatischen Zuordnung können Sie nicht die nächste zugewiesene IP-Adresse vorhersagen. Wenn Sie die möglichen NAT-IP-Adressen vorab kennen (z. B. zum Erstellen einer Zulassungsliste), sollten Sie stattdessen die manuelle NAT-IP-Adresszuweisung verwenden.
Wenn automatisch hinzugefügte NAT-IP-Adressen nicht mehr verwendet werden, werden sie entfernt. Die Zuweisung einer Adresse wird von Public NAT jedoch nur aufgehoben, wenn die ihr zugewiesene letzte VM keine Ports mehr verwendet. Wenn die Anzahl der VMs, die Public NAT verwenden, sinkt, wird also möglicherweise die IP-Adresse nicht verringert . Der Grund dafür ist, dass Cloud NAT VMs nicht dynamisch von einer IP-Adresse zu einer anderen zuweist, da die Neuzuweisung bestehende Verbindungen unterbrechen würde. Solange mindestens eine VM eine IP-Adresse verwendet, bleibt die IP-Adresse aktiv und es können neue VMs zugewiesen werden.
Wenn Sie VMs manuell einer anderen IP-Adresse neu zuweisen möchten, um die Nutzung von IP-Adressen zu minimieren, verwenden Sie manuelle NAT-IP-Adresszuweisungen. Die manuelle NAT-IP-Adresszuweisung ermöglicht das Leeren öffentlicher NAT-IP-Adressen.
Wenn Sie später zur manuellen NAT-IP-Adresszuweisung wechseln, werden die automatisch reservierten regionalen externen IP-Adressen gelöscht. Weitere Informationen finden Sie unter Zuweisungsmethode umstellen.
Manuelle NAT-IP-Adresszuweisung. Wenn Sie diese Option auswählen, werden statische (reservierte) regionale IP-Adressen manuell erstellt und dem öffentlichen NAT-Gateway manuell zugewiesen. Sie können IP-Adressen entweder aus der Premium-Stufe- oder der Standardstufe oder aus beiden manuell zuweisen, wenn bestimmte Bedingungen erfüllt sind.
- Um die Anzahl der manuell zugewiesenen NAT-IP-Adressen zu erhöhen oder zu verringern, müssen Sie das Cloud NAT-Gateway bearbeiten.
- Wenn Sie die manuelle NAT-IP-Adresszuweisung verwenden, müssen Sie die Anzahl der regionalen externen IP-Adressen berechnen, die Sie für das öffentliche NAT-Gateway benötigen. Wenn das Gateway keine NAT-IP-Adressen mehr hat, verwirft Public NAT Pakete. Verworfene Pakete werden protokolliert, wenn Sie das Fehler-Logging mit Cloud NAT-Logging aktivieren.
- Beispiele zur Berechnung finden Sie im Beispiel zur Portreservierung.
Die maximale Anzahl von automatisch zugewiesenen oder manuell zugewiesenen NAT-IP-Adressen finden Sie unter Cloud NAT-Limits.
Manuell eine Mischung aus IP-Adressen der Premium- und Standardstufe zuweisen
Wenn Sie ein öffentliches NAT-Gateway mit der manuellen NAT-IP-Adresszuweisung erstellen, können Sie eine Mischung aus IP-Adressen der Premium-Stufe- und der Standardstufe zuweisen, solange die IP-Adressen verschiedener Netzwerkstufen nicht derselben Regel (einschließlich der Standardregel) zugewiesen sind.
Innerhalb einer Regel (einschließlich der Standardregel) müssen alle IP-Adressen, die aktiven Bereichen zugewiesen sind, derselben Netzwerkebene angehören. Wenn Sie versuchen, IP-Adressen verschiedener Ebenen als Teil derselben Regel zu verwenden, wird die Konfiguration von Google Cloud abgelehnt.
Zuweisungsmethode für Schalter
Sie können ein öffentliches NAT-Gateway von der automatischen NAT-IP-Adresszuweisung auf die manuelle NAT-IP-Adresszuweisung umstellen. Dabei können die NAT-IP-Adressen jedoch nicht beibehalten werden. Obwohl automatisch zugewiesene NAT-IP-Adressen statisch sind, können sie nicht in eine manuelle NAT-IP-Adresszuweisung übernommen werden. Sie können beispielsweise nicht zuerst ein öffentliches NAT-Gateway mit automatisch zugewiesenen NAT-IP-Adressen verwenden und später dieselben Adressen verwenden, wenn Sie auf manuell zugewiesene NAT-IP-Adressen umstellen.
Die Gruppe regionaler externer IP-Adressen, die Public NAT für die automatische Zuweisung von NAT-IP-Adressen verwendet, unterscheidet sich von den regionalen externen IP-Adressen, die Sie manuell auswählen können.
Öffentliche NAT-IP-Adressen per Drain beenden
Wenn Sie ein öffentliches NAT-Gateway mit manueller NAT-IP-Adresszuweisung konfigurieren, können Sie auswählen, was passiert, wenn Sie die Anzahl der vom Gateway verwendeten NAT-IP-Adressen reduzieren müssen:
Wenn Sie eine manuell zugewiesene NAT-IP-Adresse entfernen, werden bestehende NAT-Verbindungen sofort unterbrochen.
Sie können stattdessen eine manuell zugewiesene NAT-IP-Adresse per Drain beenden. Durch das Draining wird das öffentliche NAT-Gateway angewiesen, die NAT-IP-Adresse nicht mehr für neue Verbindungen zu nutzen, sie aber für bestehende Verbindungen weiter zu verwenden. Bestehende Verbindungen dürfen normal beendet werden und müssen nicht abrupt abgebrochen werden. Informationen zum Beenden einer IP-Adresse, die mit einem öffentlichen NAT-Gateway verknüpft ist, das keine NAT-Regeln verwendet, finden Sie unter Externe mit NAT verknüpfte IP-Adressen per Drain beenden. Informationen zum Beenden einer IP-Adresse, die mit einem NAT-Gateway verknüpft ist, das NAT-Regeln verwendet, finden Sie unter NAT-Regeln aktualisieren.
Private NAT-IP-Adressen
Eine Private NAT-Adresse ist eine regionale interne IPv4-Adresse, die aus dem primären IPv4-Adressbereich eines Private NAT-Subnetzes stammt, das sich in derselben Region und im selben VPC-Netzwerk wie ein Private NAT-Gateway befindet. Eine private NAT-IP-Adresse kann nicht im Internet weitergeleitet werden. IP-Adressen aus primären IPv4-Adressbereichen von privaten NAT-Subnetzen können nur von privaten NAT-Gateways verwendet werden. Wenn Sie ein privates NAT-Subnetz erstellen möchten, fügen Sie mit der Google Cloud CLI und dem Flag --purpose=PRIVATE_NAT
ein reines IPv4-Subnetz hinzu.
Nachdem Sie ein privates NAT-Gateway konfiguriert haben, um NAT-Dienste für ein Subnetz in einem VPC-Netzwerk bereitzustellen, können VMs mit Netzwerkschnittstellen in diesem Subnetz Pakete an Ressourcen in anderen Netzwerken senden, z. B. an VPC-Netzwerke, die mit demselben Network Connectivity Center-Hub verbunden sind wie das Netzwerk, in dem das private NAT-Gateway gehostet wird, oder an Netzwerke außerhalb von Google Cloud, die über Cloud Interconnect oder Cloud VPN mit Google Cloud verbunden sind. Beim Ausgang ändert Google Cloud die Quell-IP-Adresse in eine IP-Adresse aus dem privaten NAT-Subnetz, das mit dem Gateway verknüpft ist.
Private NAT-IP-Adressen haben folgende Merkmale:
- Privaten NAT-Gateways können keine privaten NAT-IP-Adressen automatisch zugewiesen werden. Wenn Sie stattdessen eine Regel in einem privaten NAT-Gateway erstellen, geben Sie das private NAT-Subnetz oder die privaten NAT-Subnetze manuell an. Private NAT-Subnetze müssen sich im selben VPC-Netzwerk und in derselben Region wie das Gateway befinden. Das Gateway verwendet nur IP-Adressen aus den primären IPv4-Adressbereichen der privaten NAT-Subnetze.
- Um zu ermitteln, wie viele NAT-IP-Adressen jedes Private NAT-Subnetz bereitstellen kann, verwenden Sie die folgende Formel:
2(32 - PREFIX_LENGTH) - 4
, wobeiPREFIX_LENGTH
die Subnetzmaske des primären IPv4-Adressbereichs des Private NAT-Subnetzes ist. Im primären IPv4-Adressbereich jedes Subnetzes sind vier IP-Adressen nicht verwendbar.
Ports
Jede NAT-IP-Adresse auf einem Cloud NAT-Gateway (sowohl öffentliches NAT als auch privates NAT) bietet 64.512 TCP-Quellports und 64.512 UDP-Quellports. TCP und UDP unterstützen jeweils 65.536 Ports pro IP-Adresse. Cloud NAT verwendet aber nicht die ersten 1.024 bekannten (privilegierten) Ports.
Wenn ein Cloud NAT-Gateway für ein Paket, das von einer VM gesendet wird, eine Quellnetzwerkadressübersetzung (Source Network Address Translation, SNAT) durchführt, werden die NAT-Quell-IP-Adresse und der Quellport des Pakets geändert.
Beim Erstellen eines Cloud NAT-Gateways wählen Sie aus, ob die statische Portzuweisung oder die dynamische Portzuweisung verwendet werden soll. Sie können die Portzuweisungsmethode nach dem Erstellen des Gateways ändern. Informationen dazu, wie sich die Änderung der Portzuweisungsmethode für ein Cloud NAT-Gateway auf bestehende Verbindungen auswirkt, finden Sie unter Portzuweisungsmethode umstellen.
Wenn Sie Ihrem öffentlichen NAT-Gateway manuell mehrere statische (reservierte) regionale externe IP-Adressen zugewiesen haben, kann eine einzelne VM, die das Gateway verwendet, die erforderlichen Ports von einer beliebigen der zugewiesenen NAT-IP-Adressen abrufen – sogar von mehreren NAT-IP-Adressen gleichzeitig.
Statische Portzuweisung
Wenn Sie die statische Portzuweisung konfigurieren, geben Sie eine Mindestanzahl an Ports pro VM-Instanz an. Wenn Sie die Mindestanzahl der Ports pro VM nicht angeben, verwendet Google Cloud den Standardwert.
Die statische Portzuweisung ist für öffentliche NAT standardmäßig aktiviert. Bei privater NAT wird dagegen standardmäßig die dynamische Portzuweisung verwendet.
Da allen VMs die gleiche Anzahl von Ports zugewiesen wird, funktioniert die statische Portzuweisung am besten, wenn alle VMs eine ähnliche Auslastung haben. Wenn die statische Portzuweisung konfiguriert ist, ist die Anzahl der Ports, die jeder VM zugewiesen sind, festgelegt und ändert sich nicht, wenn einige VMs mehr Ports als andere verwenden oder eine VM alle Ports belegt. Wenn die ausgehende Nutzung variiert, sollten Sie die dynamische Portzuweisung konfigurieren.
Wenn Sie die endpunktunabhängige Zuordnung für Ihr öffentliches NAT-Gateway konfigurieren möchten, müssen Sie die statische Portzuweisung verwenden. Die endpunktunabhängige Zuordnung ist für private NAT-Gateways nicht verfügbar.
Dynamische Portzuweisung
Wenn Sie die dynamische Portzuweisung konfigurieren, geben Sie eine Mindestanzahl an Ports pro VM-Instanz und eine maximale Anzahl an Ports pro VM-Instanz an.
Die dynamische Portzuweisung ist für private NAT standardmäßig aktiviert. Bei öffentlicher NAT wird standardmäßig die statische Portzuweisung verwendet.
Wenn Sie die dynamische Portzuweisung konfigurieren, kann das gleiche Cloud NAT-Gateway je nach Nutzung der VM eine unterschiedliche Anzahl von Ports pro VM zuweisen. Anfänglich wird einer VM die Mindestanzahl an Ports pro VM-Instanz zugewiesen. Wenn eine VM fast alle zugewiesenen Ports erschöpft, wird die Anzahl der der VM zugewiesenen Ports verdoppelt. Die VM kann mehr Ports bis zur maximalen Anzahl von Ports pro VM-Instanz anfordern. Wenn die Portnutzung erheblich abnimmt, werden die Ports freigegeben und können anderen VMs zugewiesen werden, die dasselbe NAT-Gateway verwenden.
Die dynamische Portzuweisung hat folgende Vorteile:
Die Anzahl der zugewiesenen, aber nicht verwendeten Ports wird reduziert.
Das NAT-Gateway überwacht die Portnutzung jeder VM und ändert die Anzahl der Ports, die jeder VM zugewiesen werden, nach Bedarf. Sie müssen nicht die Portnutzung überwachen oder die NAT-Gateway-Konfiguration anpassen.
Bevor Sie die dynamische Portzuweisung verwenden, sollten Sie Folgendes beachten:
Wenn die endpunktunabhängige Zuordnung für das Cloud NAT-Gateway aktiviert ist, können Sie die dynamische Portzuweisung nicht konfigurieren. Wenn Sie die endpunktunabhängige Zuordnung benötigen, verwenden Sie die statische Portzuweisung.
Während VMs zusätzliche Ports zugewiesen werden, kann es zu Verbindungszeitüberschreitungen oder Latenz kommen. Strategien zum Verhindern von Verbindungsabbrüchen finden Sie unter Verworfene Verbindungen mit dynamischer Portzuweisung reduzieren.
Methode zur Zuweisung von Switch-Ports
Sie können für ein bestimmtes Cloud NAT-Gateway zwischen statischer und dynamischer Portzuweisung wechseln.
Wenn Sie zur dynamischen Portzuweisung wechseln, werden bestehende NAT-Verbindungen nur dann unterbrochen, wenn eine der folgenden Bedingungen erfüllt ist:
Sie legen die maximale Anzahl von Ports pro VM auf einen Wert fest, der kleiner als die Mindestanzahl von Ports pro VM ist, die in der vorherigen NAT-Konfiguration (mit statischer Portzuweisung) angegeben ist.
Wenn in der vorherigen Konfiguration die Mindestanzahl der Ports pro VM auf mehr als
1024
festgelegt war und Sie in der neuen Konfiguration1024
als maximale Anzahl der Ports pro VM angeben, werden die vorhandenen Verbindungen unterbrochen, da die erste Bedingung Vorrang hat.Sie haben die maximale Anzahl von Ports pro VM auf einen Wert festgelegt, der unter
1024
liegt.
Sofern keine der oben genannten Bedingungen erfüllt ist, werden durch die Umstellung auf die dynamische Portzuweisung keine bestehenden NAT-Verbindungen unterbrochen.
Wenn Sie die dynamische Portzuweisung deaktivieren und zur statischen Portzuweisung wechseln, werden alle aktiven NAT-Verbindungen unterbrochen.
Verfahren für die Portreservierung
Cloud NAT verwendet das folgende Verfahren, um Tupel aus NAT-Quell-IP-Adresse und Quellport für jede VM bereitzustellen, die vom Cloud NAT-Gateway (sowohl öffentliches NAT als auch privates NAT) bedient wird.
Cloud NAT bestimmt die internen VM-IP-Adressen, für die NAT ausgeführt werden soll. Die internen IP-Adressen der VM werden durch die Subnetz-IP-Adressbereiche bestimmt, für deren Bereitstellung das Gateway konfiguriert ist.
Wenn das öffentliche NAT-Gateway so konfiguriert ist, dass NAT für den primären IP-Adressbereich des Subnetzes ausgeführt wird, das von der Netzwerkschnittstelle der VM verwendet wird, führt das Gateway NAT sowohl für die primäre interne IP-Adresse der VM als auch für alle Alias-IP-Bereiche der VM aus dem primären IP-Adressbereich des Subnetzes aus.
Wenn das öffentliche NAT-Gateway so konfiguriert ist, dass NAT für einen sekundären IP-Adressbereich des Subnetzes ausgeführt wird, der von der Netzwerkschnittstelle der VM verwendet wird, führt das Gateway NAT für alle Alias-IP-Bereiche aus dem sekundären IP-Adressbereich dieses Subnetzes aus.
Da ein privates NAT-Gateway so konfiguriert ist, dass NAT für alle IP-Adressbereiche des Subnetzes ausgeführt wird, das von der Netzwerkschnittstelle der VM verwendet wird, führt das Gateway NAT für alle IP-Bereiche dieses Subnetzes aus.
Cloud NAT passt die Mindestanzahl an Ports pro VM-Instanz bei Bedarf an. Wenn die statische Portzuweisung konfiguriert ist und das Gateway NAT für Alias-IP-Bereiche ausführt, die mehr als eine Adresse haben (Netzmaske kleiner als
/32
), passt Cloud NAT die Mindestanzahl an Ports pro VM an das Maximum dieser beiden Werte an:Die von Ihnen angegebene Mindestanzahl an Ports pro VM-Instanz
Die Zahl 1.024
In allen anderen Situationen, einschließlich wenn die dynamische Portzuweisung konfiguriert ist, fährt das Cloud NAT-Gateway mit dem nächsten Schritt fort, wobei die angegebene Mindestanzahl an Ports pro VM-Instanz als Eingabe verwendet wird. Wenn Sie keine Mindestanzahl an Ports pro VM-Instanz angeben, wird der Standardwert verwendet:
64
für die statische Portzuweisung und32
für die dynamische Portzuweisung.Cloud NAT reserviert Tupel aus NAT-Quell-IP-Adresse und Quellport für jede VM. Das Cloud NAT-Gateway verwendet die vorgegebene oder angepasste Mindestanzahl an Ports pro VM-Instanz aus dem vorherigen Schritt, um die Anzahl der Tupel aus NAT-Quell-IP-Adresse und Quellport zu berechnen, die der VM zugewiesen werden sollen.
Bei Public NAT weist Google Cloud Tupel aus NAT-Quell-IP-Adresse und Quellport mit mehreren Potenzen von zwei zu, sodass die Anzahl der Tupel aus NAT-Quell-IP-Adresse und Quellport größer oder gleich der von Ihnen angegebenen Mindestanzahl an Ports pro VM-Instanz ist.
Bei Private NAT weist Google Cloud aus Gründen der Zuverlässigkeit doppelt so viele Ports wie die erforderliche Mindestanzahl pro VM zu. Das Subnetz, aus dem Private NAT IP-Adressen und Ports zuweist, muss eine angemessene Größe haben.
Wenn das Cloud NAT-Gateway zwei oder mehr NAT-IP-Adressen verwendet, ist es möglich, dass die Tupel aus NAT-Quell-IP-Adresse und Quellport mehr als eine NAT-IP-Adresse umfassen. Eine einzelne NAT-IP-Adresse hat möglicherweise nicht genügend verfügbare Quellports, um die Anzahl der Tupel aus Quell-IP-Adresse und Quellport zu berücksichtigen, die eine VM benötigt.
Das Cloud NAT-Gateway weist jeder VM Tupel aus Quell-IP-Adresse und Quellport zu.
Wenn Sie die statische Portzuweisung konfiguriert haben, ist die Anzahl der Tupel aus Quell-IP-Adresse und Quellport unveränderlich. Jede VM darf während eines Traffic-Bursts nicht mehr als die ihr zugewiesene Anzahl von Tupeln aus Quell-IP-Adresse und Quellport verwenden.
Wenn Sie die dynamische Portzuweisung konfiguriert haben, kann sich die Anzahl der Tupel aus Quell-IP-Adresse und Quellport je nach Bedarf ändern. Wenn eine VM die aktuelle Portzuweisung fast aufgebraucht hat, weist Cloud NAT zusätzliche Ports bis zum angegebenen Wert der maximalen Anzahl an Ports pro VM-Instanz zu. Wenn die Portnutzung der VM unter einen Schwellenwert sinkt, werden die Ports freigegeben und können anderen VMs zugewiesen werden.
Anzahl der Ports pro VM erhöhen
Wenn Sie ein Cloud NAT-Gateway mit statischer Portzuordnung konfiguriert haben, wird der Traffic nicht unterbrochen, wenn Sie die Mindestanzahl der Ports pro VM auf dem Gateway erhöhen.
Wenn Sie ein Cloud NAT-Gateway mit dynamischer Portzuweisung konfiguriert haben, werden bestehende NAT-Verbindungen nicht unterbrochen und der Traffic, der über das NAT-Gateway fließt, wird nicht unterbrochen, wenn Sie die Mindest-, die Höchstzahl oder beide Anzahlen der Ports pro VM erhöhen.
Beachten Sie Folgendes, wenn Sie die Anzahl der Ports pro VM erhöhen:
Wenn Sie Public NAT mit manueller NAT-IP-Adresszuweisung verwenden, müssen Sie die Anzahl der benötigten NAT-Quell-IP-Adressen berechnen. Bevor Sie die Mindestanzahl an Ports pro VM erhöhen, weisen Sie dem öffentlichen NAT-Gateway mindestens genauso viele NAT-IP-Adressen zu.
Wenn Sie Public NAT mit automatischer NAT-IP-Adresszuweisung verwenden, führt das Erhöhen der Mindestanzahl von Ports pro VM dazu, dass das Public NAT-Gateway automatisch mehr regionale externe IP-Adressen abruft und zuweist.
Achten Sie bei der Verwendung von Private NAT darauf, dass das Subnetz, aus dem das Gateway IP-Adressen zuweist, eine ausreichende Anzahl von IP-Adressen hat.
Anzahl der Ports pro VM reduzieren
Wenn Sie ein Cloud NAT-Gateway mit statischer Portzuordnung konfiguriert haben und die Mindestanzahl an Ports pro VM auf dem Gateway reduzieren, wird kein Verbindungsausgleich ausgeführt. Bereits eingerichtete NAT-Verbindungen werden sofort unterbrochen und Clients müssen neue TCP-Verbindungen herstellen.
Wenn Sie ein Cloud NAT-Gateway mit dynamischer Portzuweisung konfiguriert haben, treffen die folgenden Aussagen zu:
- Wenn Sie die Mindestanzahl der Ports pro VM reduzieren, werden nicht die vorhandenen NAT-Verbindungen unterbrochen oder der Traffic, der über das NAT-Gateway fließt.
- Wenn Sie die maximale Anzahl von Ports pro VM reduzieren, werden alle vorhandenen NAT-Verbindungen sofort unterbrochen und die Anzahl der zugewiesenen Ports für alle VMs wird vorübergehend auf den Wert zurückgesetzt, der für die Mindestanzahl von Ports pro VM angegeben ist.
Ports und Verbindungen
Die Anzahl der Tupel aus NAT-Quell-IP-Adresse und Quellport, die ein Cloud NAT-Gateway für eine VM reserviert, begrenzt die Anzahl der Verbindungen, die eine VM zu einem eindeutigen Ziel herstellen kann:
Ein eindeutiges Ziel bedeutet ein eindeutiges 3-Tupel, das aus einer Ziel-IP-Adresse, einem Zielport und einem IP-Protokoll (z. B. TCP oder UDP) besteht.
Eine Verbindung bedeutet ein eindeutiges 5-Tupel, das aus dem Tupel aus NAT-Quell-IP-Adresse und Quellport kombiniert mit einem eindeutigen 3-Tupel-Ziel besteht. Da das UDP-Protokoll verbindungslos ist, wird das Konzept der Verbindung auf ein 5-Tupel reduziert, das einem eindeutigen UDP-Datagram zugeordnet ist.
Angenommen, ein Cloud NAT-Gateway berechnet 1.024 für die feste Anzahl von Ports für eine VM, indem es das Verfahren zur Portreservierung befolgt. Das Cloud NAT-Gateway reserviert 1.024 eindeutige Kombinationen von Tupeln aus NAT-Quell-IP-Adresse und Quellport für die VM. Das Cloud NAT-Gateway kann 1.024 gleichzeitige Verbindungen zu jedem eindeutigen Ziel-3-Tupel verarbeiten. Allerdings betrachtet Cloud NAT geschlossene Verbindungen für einen Zeitraum von 120 Sekunden nach dem Trennen der Verbindung als nicht verwendbar, was sich auf die Anzahl der genutzten Verbindungen auswirken kann.
Beispiele:
Das Gateway unterstützt 1.024 gleichzeitige Verbindungen zur Ziel-IP-Adresse
203.0.113.99
an Port80
mit dem TCP-Protokoll.Das Gateway unterstützt weitere 1.024 gleichzeitige Verbindungen zur gleichen Ziel-IP-Adresse an Port
443
mit dem TCP-Protokoll.Das Gateway unterstützt weitere 1.024 gleichzeitige Verbindungen zu einer anderen Ziel-IP-Adresse an Port
80
mit dem TCP-Protokoll.
Gleichzeitige Portwiederverwendung und endpunktunabhängige Zuordnung
Sofern sich mindestens eine Informationseinheit im Ziel-3-Tupel ändert – die Ziel-IP-Adresse, der Zielport, das Protokoll – kann dasselbe Tupel aus NAT-Quell-IP-Adresse und Quellport für viele verschiedene Verbindungen gleichzeitig verwendet werden.
Bei der öffentlichen NAT wird die endpunktunabhängige Zuordnung verwendet, wie in Abschnitt 2.3 von RFC 5128 definiert. Daher kann die Anzahl der gleichzeitigen Verbindungen, die eine Client-VM zu einem eindeutigen Ziel-3-Tupel herstellen kann, reduziert werden, wenn Public NAT mehr als einer internen IP-Adresse und einem sitzungsspezifischen Quellport einer Client-VM dasselbe NAT-Tupel aus Quell-IP-Adresse und Quellport zuweist. Die Wahrscheinlichkeit dafür ist höher, wenn die Client-VM eine große Anzahl von internen Quell-IP-Adressen besitzt und viele Verbindungen zum selben Ziel-3-Tupel herstellt. Wenn eine Client-VM zum ersten Mal ein Paket von einer internen IP-Adresse und einem sitzungsspezifischen Quellport sendet, erstellt Public NAT eine n:1-endpunktunabhängige Zuordnung zwischen folgenden Elementen:
- Das Tupel aus interner IP-Adresse und sitzungsspezifischem Quellport
- Eindeutiges Tupel aus NAT-Quell-IP-Adresse und Quellport
Wenn beispielsweise eine Client-VM ein Paket von ihrer internen IP-Adresse 10.0.0.2
über einen sitzungsspezifischen Quellport 10001
sendet, weist Public NAT 10.0.0.2:10001
zu. Dieses Tupel aus NAT-Quell-IP-Adresse und Quellport wird dann für alle nachfolgenden Verbindungen von 10.0.0.2:10001
zu einem beliebigen Ziel-3-Tupel verwendet.
Wenn dieselbe VM einen anderen sitzungsspezifischen Quellport verwendet, um ein Paket zu senden (z. B. 10.0.0.2:20002
), weist Public NAT auch ein Tupel aus NAT-Quell-IP-Adresse und Quellport für alle nachfolgenden Verbindungen von 10.0.0.2:20002
einem beliebigen Ziel-3-Tupel zu. Es ist möglich, dass Public NAT dasselbe Tupel aus NAT-Quell-IP-Adresse und Quellport beiden Tupeln aus interner IP-Adresse und sitzungsspezifischem Quellport zuweist. Dies kann in bestimmten Situationen zu einem endpunktunabhängigen Konflikt führen.
Ein detailliertes Beispiel finden Sie unter Beispiel für einen endpunktunabhängigen Zuordnungskonflikt.
Endpunktunabhängige Konflikte reduzieren
Sie können Konfigurationsänderungen vornehmen, um endpunktunabhängige Konflikte zu reduzieren. Weitere Informationen finden Sie unter Pakete mit Grund entfernt: endpunktunabhängiger Konflikt.
Verzögerung für die Wiederverwendung des TCP-Quellports
Nachdem ein Cloud NAT-Gateway eine TCP-Verbindung beendet hat, erzwingt Google Cloud eine Verzögerung, bevor das Gateway dasselbe Tupel aus NAT-Quell-IP-Adresse und Quellport mit demselben Ziel (Ziel-IP-Adresse, Zielport und Protokoll) wiederverwenden kann. Die Länge der Verzögerung wird von der Einstellung TCP TIME_WAIT Timeout gesteuert.
Bei Bedarf können Sie diese Verzögerung reduzieren, indem Sie den Standardwert des Zeitlimits „TCP TIME_WAIT“ ändern. Informationen zum Ändern von NAT-Zeitlimits finden Sie unter NAT-Zeitlimits ändern. Alternativ haben Sie folgende Möglichkeiten:
Erhöhen Sie die Mindestanzahl der Ports pro VM-Instanz, damit das Portreservierungsverfahren der VM mehr Tupel aus NAT-Quell-IP-Adresse und Quellport zuweist.
Wenn eine VM TCP-Verbindungen mit derselben Ziel-IP-Adresse und demselben Zielport schnell und einfach mit demselben Protokoll öffnen und beenden muss, sollten Sie anstelle von Cloud NAT der VM eine externe IP-Adresse zuweisen und Firewallregeln verwenden, um unerwünschte eingehende Verbindungen zu beschränken.
Quellports und Sicherheit
Wenn Sie die zufällige Quellportanordnung als Sicherheitsmaßnahme verwenden, müssen Sie Folgendes beachten:
Erhöhen Sie die Mindestanzahl der Ports pro VM-Instanz, damit das Portreservierungsverfahren der VM mehr Tupel aus NAT-Quell-IP-Adresse und Quellport zuweist. Wenn Sie die Mindestanzahl der Ports pro VM-Instanz erhöhen, wird jeder VM ein Bereich von Ports nach dem Zufallsprinzip zugewiesen. Der aus diesem Bereich ausgewählte Quellport ist jedoch sequenziell.
Weisen Sie der VM eine externe IP-Adresse zu, anstatt Public NAT zu verwenden.
Beispiele
Die folgenden Beispiele zeigen, wie Cloud NAT NAT-Quell-IP-Adressen und Quellports für eine VM reserviert und NAT für Pakete an das Internet ausführt.
Portreservierung
Die folgenden Beispiele zeigen Anwendungsbereiche des Verfahrens für die Portreservierung:
Angenommen, Sie konfigurieren ein öffentliches NAT-Gateway, um NAT für den primären IP-Adressbereich eines Subnetzes bereitzustellen, und die VMs, die dieses Subnetz verwenden, haben keine Alias-IP-Bereiche aus dem primären IP-Adressbereich des Subnetzes. Runden Sie das Ergebnis eines beliebigen Divisionsvorgangs auf die nächste Ganzzahl ab. ⌊⌋ ist die Funktion für die Untergrenze (größte Ganzzahl), d. h. jedes Bruchergebnis der Division wird verworfen.
Wenn Sie das öffentliche NAT-Gateway mit einer einzelnen NAT-IP-Adresse mithilfe der manuellen Zuweisung konfigurieren und die Mindestanzahl an Ports pro VM-Instanz auf 64 festlegen, kann das Gateway NAT-Dienste für bis zu 1.008 VMs bereitstellen:
⌊(1 NAT-IP-Adresse) × (64.512 Ports pro Adresse) / (64 Ports pro VM)⌋ = 1.008 VMs
Wenn Sie mehr als 1.008 VMs unterstützen müssen, können Sie dem Cloud NAT-Gateway eine zweite NAT-IP-Adresse zuweisen. Bei zwei NAT-IP-Adressen und einer Mindestanzahl von 64 Ports pro VM können Sie 2.016 VMs unterstützen:
⌊(2 NAT-IP-Adressen) × (64.512 Ports pro Adresse) / (64 Ports pro VM)⌋ = 2.016 VMs
Wenn Sie die Mindestanzahl an Ports pro VM auf 4.096 festlegen, kann jede NAT-IP-Adresse 15 VMs unterstützen. Diese Berechnung wird auf die nächste Ganzzahl abgerundet:
⌊(1 NAT-IP-Adresse) × (64.512 Ports pro Adresse) ÷ (4.096 Ports pro VM)⌋ = 15 VMs
Angenommen, Sie konfigurieren ein privates NAT-Gateway, um NAT für alle IP-Adressen eines Subnetzes bereitzustellen:
Die Mindestgröße eines Subnetzes beträgt acht IPv4-Adressen, was einer Subnetzmaske von
/29
entspricht. Wenn Sie ein Private NAT-Gateway mit einem NAT-Subnetz der Mindestgröße konfigurieren und die Mindestanzahl an Ports pro VM-Instanz auf 64 festlegen, kann das Gateway NAT-Dienste für bis zu 2.016 VMs bereitstellen:⌊(2 (32–29) – 4) NAT-IP-Adressen × (64.512 Ports pro Adresse) ÷ (64 Ports pro VM × 2)⌋ = 2.016 VMs
Wenn Sie im vorherigen Beispiel die Mindestanzahl an Ports pro VM-Instanz auf 1.024 festlegen, kann das Gateway NAT-Dienste für bis zu 126 VMs bereitstellen:
⌊(2 (32–29) – 4) NAT-IP-Adressen × (64.512 Ports pro Adresse) ÷ (1.024 Ports pro VM × 2)⌋ = 126 VMs
Wenn Sie ein Private NAT-Gateway mit einer NAT-Subnetzmaske von
/28
konfigurieren und die Mindestanzahl an Ports pro VM-Instanz auf 64 festlegen, kann das Gateway NAT-Dienste für bis zu 6.048 VMs bereitstellen:⌊(2 (32–28) – 4) NAT-IP-Adressen × (64.512 Ports pro Adresse) ÷ (64 Ports pro VM × 2)⌋ = 6.048 VMs
Endpunktunabhängiger Zuordnungskonflikt
Im folgenden Beispiel wird dargestellt, wie die endpunktunabhängige Zuordnung die Anzahl der gleichzeitigen Verbindungen von einer Client-VM zu demselben Ziel-3-Tupel reduzieren kann, selbst wenn genügend freie Tupel aus NAT-Quell-IP-Adresse und Quellport für die Client-VM vorhanden sind.
Angenommen, Sie haben ein öffentliches NAT-Gateway konfiguriert, um NAT für den primären IP-Adressbereich eines Subnetzes bereitzustellen. Sie haben eine Client-VM mit einer Netzwerkschnittstelle erstellt, deren primäre interne IP-Adresse 10.0.0.2
in diesem Subnetz ist. Die Beispiel-VM hat keine externe IP-Adresse, die der zugehörigen Netzwerkschnittstelle zugewiesen ist.
Die VM öffnet eine Verbindung mit diesen Eigenschaften:
- Interne Quell-IP-Adresse und Quellport:
10.0.0.2:10001
- Ziel-3-Tupel:
203.0.113.1:80
mit TCP - Public NAT verwendet das folgende Tupel aus NAT-Quell-IP-Adresse und Quellport:
192.0.2.10:30009
- Interne Quell-IP-Adresse und Quellport:
Die VM öffnet eine zweite Verbindung mit den folgenden Eigenschaften:
- Interne Quell-IP-Adresse und Quellport:
10.0.0.2:10002
- Ziel-3-Tupel:
203.0.113.2:80
mit TCP - Public NAT kann für diese Verbindung auch dasselbe Tupel aus NAT-Quell-IP-Adresse und Quellport (
192.0.2.10:30009
) verwenden. Es ist möglich, dasselbe Tupel aus NAT-Quell-IP-Adresse und Quellport für eine andere Client-IP-Adresse und einen sitzungsspezifischen Quellport zu verwenden.
- Interne Quell-IP-Adresse und Quellport:
Während sowohl die erste als auch die zweite Verbindung aktiv sind, kann Public NAT keine dritte TCP-Verbindung mit den folgenden Eigenschaften öffnen:
- Gleiche interne Quell-IP-Adresse und gleicher Quellport wie bei der ersten Verbindung:
10.0.0.2:10001
- Gleiches Ziel-3-Tupel wie bei der zweiten Verbindung:
203.0.113.2:80
mit TCP
Dieser dritte Verbindungsversuch wird mit einem endpunktunabhängigen Konfliktfehler abgebrochen, da die durch die erste Verbindung eingerichtete endpunktunabhängige Zuordnung vorschreibt, dass alle Verbindungen von
10.0.0.2:10001
dieselbe NAT-Quell-IP-Adresse und denselben Quellport-Tupel192.0.2.10:30009
verwenden müssen.192.0.2.10:30009
wird jedoch bereits von der zweiten TCP-Verbindung zu203.0.113.2:80
verwendet.- Gleiche interne Quell-IP-Adresse und gleicher Quellport wie bei der ersten Verbindung:
Zur Vermeidung von Mehrdeutigkeit ist ein nachfolgender Verbindungsversuch in diesem Beispiel erfolgreich, sofern eine der folgenden Bedingungen zutrifft:
- Die erste TCP-Verbindung wurde getrennt. Durch das Schließen der Verbindung wird die endpunktunabhängige Zuordnung zwischen
10.0.0.2:10001
und192.0.2.10:30009
entfernt, sodass die dritte Verbindung einem anderen Tupel aus NAT-Quell-IP-Adresse und Quellport zugeordnet werden kann, um über TCP mit203.0.113.2:80
zu kommunizieren. - Die zweite TCP-Verbindung wurde getrennt. Dadurch kann
10.0.0.2:10001
die NAT-Quell-IP-Adresse und den Quellport192.0.2.10:30009
verwenden, um über TCP mit203.0.113.2:80
zu kommunizieren. - Beim dritten Verbindungsversuch wird ein anderer sitzungsspezifischer (interner) Quellport ausgewählt. In diesem Beispiel hat eine endpunktunabhängige Zuordnung eine n:1-Zuordnung für interne NAT-Quell-IP-Adressen und Quellports
10.0.0.2:10001
und10.0.0.2:10002
eingerichtet, um192.0.2.10:30009
zu verwenden, wenn die Kommunikation mit203.0.113.2:80
über TCP erfolgt. Wenn beim dritten Verbindungsversuch ein sitzungsspezifischer Quellport verwendet wird, der sich von10001
und10002
unterscheidet, besteht die Möglichkeit, eine andere NAT-Quell-IP-Adresse und einen anderen Quellport zur Kommunikation mit203.0.113.2:80
über TCP zu verwenden. - Die endpunktunabhängige Zuordnung ist deaktiviert.. Die neue Verbindung von
10.0.0.2:10001
muss dann nicht192.0.2.10:30009
verwenden und kann somit eine andere NAT-Quell-IP-Adresse und einen anderen Quellport verwenden.
- Die erste TCP-Verbindung wurde getrennt. Durch das Schließen der Verbindung wird die endpunktunabhängige Zuordnung zwischen
Methoden, mit denen Sie Konflikte vermeiden können, finden Sie unter Endpunktunabhängige Konflikte reduzieren.
Nächste Schritte
- Richten Sie ein öffentliches NAT-Gateway ein.
- Richten Sie ein Private NAT-Gateway ein.
- Eigene Beispielkonfiguration für Compute Engine erstellen
- Beispielkonfiguration für GKE erstellen
- Häufige Probleme beheben