Deploying and configuring different virtual networks for different workloads

US11570146B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-11570146-B2
Application numberUS-202016897704-A
CountryUS
Kind codeB2
Filing dateJun 10, 2020
Priority dateApr 1, 2020
Publication dateJan 31, 2023
Grant dateJan 31, 2023

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Some embodiments of the invention provide a method for deploying network elements for a set of machines in a set of one or more datacenters. The datacenter set is part of one availability zone in some embodiments. The method receives intent-based API (Application Programming Interface) requests, and parses these API requests to identify a set of network elements to connect and/or perform services for the set of machines. In some embodiments, the API is a hierarchical document that can specify multiple different compute and/or network elements at different levels of compute and/or network element hierarchy. The method performs automated processes to define a virtual private cloud (VPC) to connect the set of machines to a logical network that segregates the set of machines from other machines in the datacenter set. In some embodiments, the set of machines include virtual machines and containers, the VPC is defined with a supervisor cluster namespace, and the API requests are provided as YAML files.

First claim

Opening claim text (preview).

We claim: 1. A method of deploying and connecting machines in a set of one or more datacenters, the method comprising: deploying a guest cluster comprising a plurality of Kubernetes Pods; deploying a supervisor cluster comprising a plurality virtual machines (VMs) including at least one particular VM that performs management plane operations for the plurality of Kubernetes Pods of the guest cluster; defining a first private network with a first subnet in the datacenter set to connect the VMs in the supervisor cluster; defining a second private network with a second subnet in the datacenter set to connect the Kubernetes Pods; and configuring routers of the first and second private networks to advertise their subnets to at least one gateway router of the datacenter set for the gateway router to advertise the first subnet of the first private network to the second private network and to advertise the second subnet of the second private network to the first private network, wherein said advertising by the gateway router allows machines in one private network to forward data messages to machines in a different private network, said data messages including management-plane data messages sent by the particular VM, which is in the supervisor cluster and is connected to the first private network, to Kubernetes Pods that are in the guest cluster and are connected to the second network. 2. The method of claim 1 , wherein the data messages are for debug operations performed by a VM in the supervisor cluster on Pods in the guest cluster. 3. The method of claim 1 further comprising configuring the gateway router with a default rule that prevents the gateway from advertising the first and second subnets to an external network outside of the datacenter set. 4. The method of claim 3 further comprising deploying and configuring at least one gateway router for the guest cluster and a gateway router for the supervisor cluster, wherein the gateway routers of the guest cluster and the supervisor cluster advertise the first and second subnets to the gateway router of the datacenter set. 5. The method of claim 1 further comprising defining a first firewall rule to drop ingress traffic to the VMs; defining a second firewall rule to allow ingress traffic to each particular VM from other VMs in a same sub-network as the particular VM, the second firewall rule having a higher priority than the first firewall rule; and distributing the first and second firewall rules to distributed firewall engines for each of the VMs. 6. The method of claim 1 further comprising defining a firewall rule to allow ingress traffic to each particular VM in a set of VMs from a load balanced network address associated with a downlink port of the gateway that is used for forwarding data messages for a load-balanced operation performed by the set of VMs. 7. The method of claim 1 further comprising: deploying a gateway router for the guest cluster (GC); defining a default first firewall rule to reject ingress traffic at the GC gateway router; defining a second firewall rule to allow ingress traffic at the GC gateway router from an IP address used to source network address translate (SNAT) IP addresses in the first subnet, the second firewall rule having a higher priority than the first firewall rule; and distributing the first and second firewall rules to GC gateway router. 8. The method of claim 1 further comprising: deploying a gateway router for the guest cluster (GC); defining a default first firewall rule to reject ingress traffic at the GC gateway router; defining a second firewall rule to allow ingress traffic at the GC gateway router that is addressed to a load balanced service IP of the guest cluster, the second firewall rule having a higher priority than the first firewall rule; and distributing the first and second firewall rules to GC gateway router. 9. A non-transitory machine readable medium storing a program for connecting machines in a set of one or more datacenters, the program for execution by at least one processing unit, the program comprising sets of instructions for: defining a supervisor cluster comprising a plurality virtual machines (VMs); defining a first private network with a first subnet in the datacenter set to connect the VMs in the supervisor cluster; defining a guest cluster comprising a plurality of Kubernetes Pods; defining a second private network with a second subnet in the datacenter set to connect the Kubernetes Pods; and configuring routers of the first and second private networks to advertise their subnets to at least one gateway router of the datacenter set for the gateway router to advertise the first subnet of the first private network to the second private network and to advertise the second subnet of the second private network to the first private network, wherein the advertising by the gateway router allows machines in one private network to forward data messages to machines in the other private network, wherein the data messages are for management plane operations performed by a VM in the supervisor cluster for Pods in the guest cluster. 10. The non-transitory machine readable medium of claim 9 , wherein the data messages are for debug operations performed by a VM in the supervisor cluster on Pods in the guest cluster. 11. The non-transitory machine readable medium of claim 9 , wherein the program further comprises a set of instructions for configuring the gateway router with a default rule that prevents the gateway from advertising the first and second subnets to an external network outside of the datacenter set. 12. The non-transitory machine readable medium of claim 11 , wherein the program further comprises a set of instructions for deploying and configuring at least one gateway router for the guest cluster and a gateway router for the supervisor cluster, wherein the gateway routers of the guest cluster and the supervisor cluster advertise the first and second subnets to the gateway router of the datacenter set. 13. The non-transitory machine readable medium of claim 9 , wherein each gateway router is a logical router implemented by a plurality of physical routers. 14. The non-transitory machine readable medium of claim 9 , wherein the program further comprises sets of instructions for: defining a first firewall rule to drop ingress traffic to the VMs; defining a second firewall rule to allow ingress traffic to each particular VM from other VMs in a same sub-network as the particular VM, the second firewall rule having a higher priority than the first firewall rule; and distributing the first and second firewall rules to distributed firewall engines for each of the VMs. 15. The non-transitory machine readable medium of claim 9 , wherein the program further comprises a set of instructions for defining a firewall rule to allow ingress traffic to each particular VM in a set of VMs from a load balanced network address associated with a downlink port of the gateway that is used for forwarding data messages for a load-balanced operation performed by the set of VMs. 16. The non-transitory machine readable medium of claim 9 , wherein the program further comprises sets of instructions for: deploying a gateway router for the guest cluster (GC); defining a default first firewall rule to reject ingress traffic at the GC gateway router; defining a second firewall rule to allow ingress traffic at the GC gateway router from an IP address used to source network address translate (SNAT) IP addresses in the first subnet, the second firewall rule having a higher priority than th

Assignees

Inventors

Classifications

  • Architectural arrangements, e.g. perimeter networks or demilitarized zones · CPC title

  • for accessing one among a plurality of replicated servers · CPC title

  • Arrangements for connecting between networks having differing types of switching systems, e.g. gateways · CPC title

  • Distribution of virtual machine instances; Migration and load balancing · CPC title

  • Interprogram communication · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US11570146B2 cover?
Some embodiments of the invention provide a method for deploying network elements for a set of machines in a set of one or more datacenters. The datacenter set is part of one availability zone in some embodiments. The method receives intent-based API (Application Programming Interface) requests, and parses these API requests to identify a set of network elements to connect and/or perform servic…
Who is the assignee on this patent?
Vmware Inc
What technology area does this patent fall under?
Primary CPC classification G06F9/45558. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jan 31 2023 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).