Method and apparatus for providing a service with a plurality of service nodes
US-2016094454-A1 · Mar 31, 2016 · US
US11570146B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-11570146-B2 |
| Application number | US-202016897704-A |
| Country | US |
| Kind code | B2 |
| Filing date | Jun 10, 2020 |
| Priority date | Apr 1, 2020 |
| Publication date | Jan 31, 2023 |
| Grant date | Jan 31, 2023 |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
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.
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
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
Related publications grouped by family.
Answers are generated from the same data shown on this page.