Hitless upgrade for network control applications

US9973382B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9973382-B2
Application numberUS-201314069267-A
CountryUS
Kind codeB2
Filing dateOct 31, 2013
Priority dateAug 15, 2013
Publication dateMay 15, 2018
Grant dateMay 15, 2018

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.

A method for upgrading a set of controller nodes in a controller cluster that manages a plurality of forwarding elements in a way that minimizes dataplane outages. The method of some embodiments upgrades the control applications of a subset of the controller nodes before upgrading a decisive controller node. Once the decisive controller node is upgraded, the method switches the controller cluster to use a new version of the control applications.

First claim

Opening claim text (preview).

We claim: 1. A method for upgrading a controller cluster comprising a plurality of controller nodes, the controller cluster for managing a plurality of forwarding elements, each controller node executing a version of a network control application, the method comprising: upgrading a first subset of the plurality of controller nodes to execute a newer version of the network control application while managing the forwarding elements with a second subset of the plurality of controller nodes that execute an older version of the network control application; upon completion of the upgrade of the first subset of controller nodes, upgrading a decisive controller node in the second subset of controller nodes to signal the controller cluster to manage the forwarding elements with the first subset of controller nodes; upgrading the second subset of controller nodes to the newer version of the network control application while managing the forwarding elements with the first subset of controller nodes and the decisive controller node; and upon completion of the upgrade of the second subset of controller nodes, managing the forwarding elements with the first and second subsets of controller nodes. 2. The method of claim 1 , wherein the forwarding elements comprise a plurality of virtual interfaces (VIFs), wherein upgrading the controller nodes of the first subset comprises upgrading a set of forwarding data for each VIF in the plurality of VIFs. 3. The method of claim 1 , wherein managing the forwarding elements with the first subset of controller nodes comprises using the first subset of controller nodes to write to a first set of tables on the forwarding elements, wherein managing the forwarding elements with the second subset of controller nodes comprises using the second subset of controller nodes to write to a second, different set of tables on the forwarding elements, wherein the first and second sets of tables are for storing records regarding forwarding behavior of the forwarding elements. 4. The method of claim 3 , wherein storing records regarding the forwarding behavior of the forwarding elements comprises storing flows that implement a forwarding behavior on the forwarding elements. 5. The method of claim 4 , wherein a particular packet received at a particular forwarding element is forwarded according to one of the first and second sets of tables based on a version bit located in metadata of the particular packet. 6. The method of claim 5 , wherein managing the forwarding elements with the second subset further comprises setting a particular value in the version bit for packets passing through the forwarding elements, wherein managing the forwarding elements with the first subset further comprises setting a different value in the version bit for packets passing through the forwarding elements. 7. The method of claim 4 , wherein the forwarding elements comprise a set of logical forwarding elements and a set of physical forwarding elements, wherein managing the forwarding elements with the first subset of controller nodes further comprises implementing the set of logical forwarding elements on the set of physical forwarding elements using the newer version of the network control application. 8. The method of claim 7 , wherein the set of logical forwarding elements comprises a first set of logical forwarding elements for a first user and a second set of logical forwarding elements for a second user. 9. The method of claim 7 further comprising: generating a set of flows on the first subset of controller nodes, the set of flows for implementing the set of logical forwarding elements on the set of physical forwarding elements; and writing the set of flows to the second set of tables on the set of physical forwarding elements. 10. The method of claim 1 , wherein the controller cluster performs a master election for the forwarding elements when availability for a controller node changes. 11. A non-transitory machine readable medium storing a program for execution by at least one processing unit, the program for coordinating the upgrade of a controller cluster comprising a plurality of controller nodes, the controller cluster for managing a plurality of forwarding elements, each controller node executing a version of a network control application, the program comprising sets of instructions for: upgrading a first subset of the plurality of controller nodes to execute a newer version of the network control application while managing the forwarding elements with a second subset of the plurality of controller nodes that execute an older version of the network control application; upon completion of the upgrade of the first subset of controller nodes, upgrading a decisive controller node in the second subset of controller nodes to signal the controller cluster to manage the forwarding elements with the first subset of controller nodes; upgrading the second subset of controller nodes to the newer version of the network control application while managing the forwarding elements with the first subset of controller nodes and the decisive controller node; and upon completion of the upgrade of the second subset of controller nodes, managing the forwarding elements with the first and second subsets of controller nodes. 12. The non-transitory machine readable medium of claim 11 , wherein the first subset of controller nodes has the same number of controller nodes as the second subset. 13. The non-transitory machine readable medium of claim 11 , wherein the set of instructions for upgrading the first subset comprises sets of instructions for: determining whether a controller node is a master or a standby controller; and when the controller node is a standby controller, selecting the standby controller as part of the first subset. 14. The non-transitory machine readable medium of claim 11 , wherein the forwarding elements comprise a set of physical forwarding elements and a set of logical forwarding elements, wherein the set of instructions for managing forwarding elements with the first subset of controller nodes comprises a set of instructions for implementing the set of logical forwarding elements on the set of physical forwarding elements. 15. The non-transitory machine readable medium of claim 11 , the set of instructions for upgrading the first subset of controller nodes comprises a set of instructions for electing a master controller node from the first subset of controller nodes for each forwarding element. 16. An apparatus comprising: a processing unit; a storage for storing a program for coordinating the upgrade of a controller cluster comprising a plurality of controller nodes, the controller cluster for managing a plurality of forwarding elements, each controller node executing a version of a network control application, the program comprising sets of instructions for: upgrading a first subset of the plurality of controller nodes to execute a newer version of the network control application while managing the forwarding elements with a second subset of the plurality of controller nodes that execute an older version of the network control application; upon completion of the upgrade of the first subset of controller nodes, upgrading a decisive controller node in the second subset of controller nodes to signal the controller cluster to manage the forwarding elements with the first subset of controller nodes; upgrading the second subset of controller nodes to the newer version of the network control application while managing the forwarding elements with the first subset of controller nodes and the decisive

Assignees

Inventors

Classifications

  • involving the movement of software or configuration parameters  (network booting or remote initial program loading [RIPL] G06F9/4416) · CPC title

  • H04L41/082Primary

    the condition being updates or upgrades of network functionality · CPC title

  • Configuration of virtualised networks or elements, e.g. virtualised network function or OpenFlow elements · 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 US9973382B2 cover?
A method for upgrading a set of controller nodes in a controller cluster that manages a plurality of forwarding elements in a way that minimizes dataplane outages. The method of some embodiments upgrades the control applications of a subset of the controller nodes before upgrading a decisive controller node. Once the decisive controller node is upgraded, the method switches the controller clust…
Who is the assignee on this patent?
Nicira Inc
What technology area does this patent fall under?
Primary CPC classification H04L41/082. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue May 15 2018 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 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).