As known in the field of computer networking, a load balancer is a physical or virtual network device that (1) intercepts, from clients, network traffic directed to one or more services (e.g., an application, a website, etc.), and (2) distributes that traffic across a cluster of real servers configured to host the services. By intercepting and distributing network traffic in this manner, the load balancer can provide greater service reliability (by, e.g., directing traffic away from failed servers), better service performance (by, e.g., reducing the load on each real server), and greater security (by, e.g., isolating the real servers from the clients).
Generally speaking, the process of enabling load balancing for a particular service in a network environment involves configuring a virtual IP address (VIP) for the service on a load balancer of the environment. This VIP, which is associated with a physical ingress port (or group of ingress ports) of the load balancer, is presented to external clients as the endpoint address of the service. In addition, the process involves associating, on the load balancer, the VIP (and/or the service) with the IP addresses of a number of real servers in the network environment. The real servers are configured to host the service identified by the VIP. With this configuration in place, when a client attempts to access the service using the VIP, the load balancer receives the client request because the VIP points to the load balancer rather than the real servers. The load balancer then applies a load balancing algorithm (e.g., round robin, weighted round robin, etc.) to select a particular real server for handling the request from among the group of real servers associated with the service/VIP and forwards the request, using network address translation, to the selected real server.
In a network environment that comprises a single load balancer, enabling load balancing for a service is straightforward because there is no choice involved in terms of selecting which load balancer will host the service's VIP (and thus will carry out load balancing duties for the service); the service can only be configured on the environment's singular load balancer. However, in network environments that comprise a pool of multiple available load balancers such as a large-scale data center, enabling load balancing for a service involves answering a threshold question of which load balancer in the environment should be configured to handle the traffic for the service. Once a particular load balancer in a pool of available load balancers is selected, the network administrator can perform the tasks of configuring the VIP and real server IP addresses on that selected load balancer as discussed above.
In most multi-load balancer environments today, the question of load balancer selection is typically addressed manually and in an ad-hoc manner by network administrators. For example, a network administrator may select a load balancer at random, or based on the administrator's perception of what the “best” load balancer should be in view of the nature of the service. This manual, ad-hoc approach can lead to inefficient usage of load balancer resources, since the network administrator may select a load balancer that he/she thinks is appropriate, when in fact the selection of a different load balancer may result in, e.g., less resource use, better service performance, etc.
Accordingly, it would be desirable to have a more structured and automated approach for load balancer selection in a multi-load balancer environment that allows for optimized usage of load balancer resources.
Techniques for performing intelligent load balancer selection in a multi-load balancer environment are provided. In one embodiment, a computer system can generate a user interface for deploying a virtual IP address (VIP) on a load balancer in a network environment, where the network environment includes a plurality of load balancers, and where the user interface presents a plurality of criteria for selecting one of the plurality of load balancers. The computer system can further receive, from a user, a selection of one or more of the plurality of criteria, and can collect, from each load balancer in the plurality of load balancers, statistics that are relevant to the one or more criteria. The computer system can then select a load balancer from among the plurality of load balancers based on the one or more criteria and the collected statistics.
The following detailed description and accompanying drawings provide a better understanding of the nature and advantages of particular embodiments.
In the following description, for purposes of explanation, numerous examples and details are set forth in order to provide an understanding of various embodiments. It will be evident, however, to one skilled in the art that certain embodiments can be practiced without some of these details, or can be practiced with modifications or equivalents thereof.
The present disclosure provides techniques for intelligently selecting a load balancer in a multi-load balancer network environment for the purpose of handling load balancing duties for a service (i.e., hosting a VIP for that service). In one set of embodiments, a computer system can generate a user interface for deploying the VIP, where the user interface includes a set of criteria that should be satisfied when selecting a load balancer in the environment that will host the VIP. This set of criteria can include, e.g., resource-based criteria (e.g., CPU usage, memory usage, etc.), load balancing performance-based criteria (e.g., total concurrent sessions, total concurrent connections, total packet throughput, minimum latency, etc.), location-based criteria (e.g., minimum geographic distance between load balancer and real servers), and/or others. In a particular embodiment, these criteria can be preconfigured by an administrator and presented in the user interface as one or more “policies.”
The computer system can then receive, from a user, a selection of one or more of the criteria/policies, and can collect statistics/information from the load balancers in the environment that are relevant to the chosen criteria/policies, such as current resource usage of each load balancer (e.g., CPU usage, memory usage, etc.), current load balancing statistics of each load balancer (e.g., number of active connections/sessions, etc.), and so on.
Finally, the computer system can select a load balancer from the pool of available load balancers in a manner that most optimally satisfies the chosen criteria/policies (based on the statistics/information collected from each load balancer). For example, in a case where the user has specified a resource-based criterion of CPU usage less than 50%, the computer system can select an available load balancer whose current CPU usage is the furthest below 50%. As another example, in a case where the user has specified a load balancing performance-based criterion of 100K concurrent connections, the computer system can select an available load balancer whose current workload allows for at least this level of performance (by, e.g., calculating max concurrent connections minus current concurrent connections). In this way, the computer system can select the most appropriate (i.e., “best”) load balancer in view of the user-defined criteria/policies and the current state of the load balancers in the environment.
In certain embodiments, the pool of available load balancers can include both physical and virtual load balancers, as well as load balancers from different vendors. The computer system can communicate with each of these different load balancers using the APIs, protocols, and commands native to the load balancer.
In further embodiments, the computer system described above can be implemented using a Software Defined Networking (SDN) controller, and the processing performed by the computer system can be embodied in an SDN application running on the controller.
Accordingly, these embodiments can leverage existing SDN infrastructure in the network environment to facilitate load balancer selection.
These and other features of the present disclosure are discussed in further detail in the sections that follow.
In the embodiment of
As noted in the Background section, one challenge with enabling load balancing for services in a multi-load balancer network environment such as
To address the foregoing and other similar issues, network environment 100 includes a novel load balancer (LB) selection engine 108 running on a computer system 110 within network environment 100. In this particular embodiment, computer system 110 is an SDN controller and LB selection engine is implemented within an SDN application 112 executing on SDN controller 110. With this SDN-based approach, application 112 can seamlessly fit in as another network service within the SDN infrastructure of environment 100, and data from engine 108/application 112 can be easily consumed/leveraged by other SDN applications running on SDN controller 110 as they will typically make use of similar data formats and a shared data store. In alternative embodiments, LB selection engine 108 can be implemented in a non-SDN context.
As described further detail below, at a time a user (e.g., user 114) wishes to enable load balancing with respect to a new or existing service within environment 100, LB selection engine 108 can receive, from user 114 via a user interface 116, one or more criteria (e.g., preconfigured policies) for selecting a load balancer that will host the VIP for the service. LB selection engine 108 can then communicate with load balancers 102 to collect statistics/information that are relevant to the chosen criteria. Finally, LB selection engine 108 can select, from among load balancers 102(1)-(N), the “best” load balancer for hosting the VIP in view of the user-chosen criteria and the collected statistics/information. Since this selection process is performed in an automated manner (i.e., without manual intervention or input from a user/administrator, other than the criteria/policies chosen via user interface 116), LB selection engine 108 can take the guesswork out of selecting an appropriate load balancer. Further since this selection process can take into account the actual operating statistics of the pool of available load balancers (to the extent that those statistics are relevant to the chosen criteria/policies), LB selection engine 108 can ensure that the load balancing resources of network environment 100 are optimally used.
It should be appreciated that
Starting with block 202, at a time user 114 wishes to enable load balancing for a service hosted by one or more of real servers 104(1)-(M) in network environment 100, SDN application 112 can generate a user interface (e.g., interface 116) that enables user 114 to deploy a VIP for the service. This user interface can include, among other fields, a set of criteria to be satisfied when selecting a load balancer 102 in network environment 100 that will host the VIP. For example, in one set of embodiments, the set of criteria can include criteria that are based on system resource parameters such as CPU usage, memory usage, hardware information like temperature, fan operation/speed, disk usage (in the case of hardware load balancers), and/or parent hypervisor attributes (in the case of virtual load balancers). In other embodiments, the one or more criteria can further include criteria that are based on load balancing performance parameters, such as a total number of sessions, total number of connections, and/or total throughput. In yet other embodiments, the one or more criteria can further include criteria that are based on SDN parameters (e.g., inputs from SDN controller 110), such as flow table based inputs, traffic congestion information, etc. In yet other embodiments, the one or more criteria can also include criteria based on other types of parameters, such as geo-location (e.g., proximity of a given load balancer, in radius, to the service's real servers), bandwidth costs for the links between the load balancer and the real servers, and so on. One of ordinary skill in the art will recognize many variations for the types of criteria that may be used to select a load balancer.
In certain embodiments, these criteria can be grouped and presented in the user interface as one or more policies. For example,
Further in some embodiments, the particular policies and/or criteria that are presented to user 114 can be configurable by a network administrator. For example, the administrator may wish to enable certain policies/criteria for certain customers based on the license they have purchased (e.g., only allow selection of the best performance policy for those customers that have purchased the highest-cost license). The configuration of which policies/criteria will be displayed to user 114 can also be based on other factors, such as the particular load balancers that are available to the user (in the case of, e.g., a multi-tenant environment).
At block 204, LB selection engine 108 can receive one or more criteria that have been chosen by user 114 from the total set of criteria presented in the user interface at block 202. Then, at block 206, LB selection engine 108 can collect statistics and/or information from each load balancer 102(1)-(N) that are relevant to the user-chosen criteria. For instance, if user 114 has selected one or more resource-based criteria, LB selection engine 108 can collect statistics regarding the current resource usage of each load balancer (e.g., CPU usage, memory usage, etc.). Alternatively, if the user 114 has selected one or more load balancing performance-based criteria, LB selection engine 108 can collect statistics regarding the current load balancing performed by each load balancer (e.g., number of sessions, connections, etc.).
In certain embodiments, LB selection engine 108 can specifically query load balancers 102 for these statistics/information. In other embodiments, these statistics/information can be pushed from the load balancers to engine 108. Further, in embodiments where load balancers 102 each support a different communication protocol or API, LB selection engine 108 can expose a set of interfaces that, if implemented by a load balancer vendor, can allow engine 108 to communicate with that vendor's load balancers using its native protocol/API. In alternative embodiments, LB selection engine 108 can communicate with load balancers 102 using a standardized protocol/API, such as NETCONF.
Upon collecting the statistics/information at block 206, LB selection engine 108 can evaluate the criteria against the collected statistics/information (block 208). Finally, at block 210, LB selection engine 108 can select a particular load balancer (from among load balancers 102(1)-(N)) that best meets the user-chosen criteria. For example, if user 114 has specified a performance-based criterion (such as a minimum of 100K concurrent connections), LB selection engine 108 can select a load balancer that is best able to meet (and/or exceed) that performance level in view of its current load. As another example, if user 114 has specified a location-based criterion (such as geographic distance that is no greater than X feet or miles in radius from the real servers), LB selection engine 108 can select a load balancer that is located no further than the specified distance.
In cases where the user has specified multiple criteria and/or policies, LB engine 108 can take all of the specified criteria/policies into account, such that each criterion/policy is satisfied. If there is a tie between load balancers, LB selection engine 108 can use a round-robin approach to select one of the tied load balancers. On the other hand, if none of the load balancers satisfy the user-chosen criteria, LB selection engine 108 can use round-robin (or a different approach, such as random selection) to select a load balancer from the pool of available load balancers. In some embodiments, as part of step 206, user 114 can provide a rank value for each selected criterion/policy based on importance, thereby enabling LB selection engine 108 to give higher priority to the criteria/policies with higher rank values.
Further, in cases where network environment is a multi-tenant environment (such that only a subset of load balancers 102(1)-(N) are available to user 114), LB selection engine 108 can perform its selection processing at block 210 in a manner that only takes into account those available load balancers (and does not include load balancers used by other tenants).
It should be appreciated that workflow 200 of
Further, as part of the user interface generated at block 202, SDN application 112 can include fields that allow user 114 to configure the VIP (e.g., name, IP address, port) and real servers (e.g., name, IP address, port) to be associated with that VIP, as well as other load balancing parameters (e.g., load balancing predictor algorithm, idle timeout, etc.). Examples of such fields are shown in user interface 300 of
Bus subsystem 404 can provide a mechanism for letting the various components and subsystems of computer system 400 communicate with each other as intended. Although bus subsystem 404 is shown schematically as a single bus, alternative embodiments of the bus subsystem can utilize multiple busses.
Network interface subsystem 416 can serve as an interface for communicating data between computer system 400 and other computing devices or networks. Embodiments of network interface subsystem 416 can include wired (e.g., coaxial, twisted pair, or fiber optic Ethernet) and/or wireless (e.g., Wi-Fi, cellular, Bluetooth, etc.) interfaces.
User interface input devices 412 can include a keyboard, pointing devices (e.g., mouse, trackball, touchpad, etc.), a scanner, a barcode scanner, a touch-screen incorporated into a display, audio input devices (e.g., voice recognition systems, microphones, etc.), and other types of input devices. In general, use of the term “input device” is intended to include all possible types of devices and mechanisms for inputting information into computer system 400.
User interface output devices 414 can include a display subsystem, a printer, a fax machine, or non-visual displays such as audio output devices, etc. The display subsystem can be a cathode ray tube (CRT), a flat-panel device such as a liquid crystal display (LCD), or a projection device. In general, use of the term “output device” is intended to include all possible types of devices and mechanisms for outputting information from computer system 400.
Storage subsystem 406 can include a memory subsystem 408 and a file/disk storage subsystem 410. Subsystems 408 and 410 represent non-transitory computer-readable storage media that can store program code and/or data that provide the functionality of various embodiments described herein.
Memory subsystem 408 can include a number of memories including a main random access memory (RAM) 418 for storage of instructions and data during program execution and a read-only memory (ROM) 420 in which fixed instructions are stored. File storage subsystem 410 can provide persistent (i.e., non-volatile) storage for program and data files and can include a magnetic or solid-state hard disk drive, an optical drive along with associated removable media (e.g., CD-ROM, DVD, Blu-Ray, etc.), a removable flash memory-based drive or card, and/or other types of storage media known in the art.
It should be appreciated that computer system 400 is illustrative and not intended to limit embodiments of the present invention. Many other configurations having more or fewer components than computer system 400 are possible.
The above description illustrates various embodiments of the present invention along with examples of how aspects of the present invention may be implemented. The above examples and embodiments should not be deemed to be the only embodiments, and are presented to illustrate the flexibility and advantages of the present invention as defined by the following claims. For example, although certain embodiments have been described with respect to particular process flows and steps, it should be apparent to those skilled in the art that the scope of the present invention is not strictly limited to the described flows and steps. Steps described as sequential may be executed in parallel, order of steps may be varied, and steps may be modified, combined, added, or omitted. As another example, although certain embodiments have been described using a particular combination of hardware and software, it should be recognized that other combinations of hardware and software are possible, and that specific operations described as being implemented in software can also be implemented in hardware and vice versa.
The specification and drawings are, accordingly, to be regarded in an illustrative rather than restrictive sense. Other arrangements, embodiments, implementations and equivalents will be evident to those skilled in the art and may be employed without departing from the spirit and scope of the invention as set forth in the following claims.
The present application is a continuation of U.S. patent application Ser. No. 14/848,035, filed Sep. 8, 2015, entitled “INTELLIGENT LOAD BALANCER SELECTION IN A MULTI-LOAD BALANCER ENVIRONMENT” which claims the benefit and priority under U.S.C. 119(e) of U.S. Provisional Application No. 62/191,073, filed Jul. 10, 2015, entitled “POLICY-BASED SMART LOAD BALANCER SELECTION IN A MULTI-LOAD BALANCER ENVIRONMENT.” The entire contents of these applications are incorporated herein by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
5774660 | Brendel et al. | Jun 1998 | A |
7103647 | Aziz | Sep 2006 | B2 |
7292535 | Folkes et al. | Nov 2007 | B2 |
7373500 | Ramelson | May 2008 | B2 |
7519056 | Ishwar et al. | Apr 2009 | B2 |
7768959 | Chen et al. | Aug 2010 | B1 |
8032634 | Eppstein | Oct 2011 | B1 |
8046694 | Lappas | Oct 2011 | B1 |
8234650 | Eppstein | Jul 2012 | B1 |
8559314 | Yedavalli et al. | Oct 2013 | B2 |
8593958 | Zhang | Nov 2013 | B2 |
8644149 | Yedavalli | Feb 2014 | B2 |
8787154 | Medved et al. | Jul 2014 | B1 |
8819275 | Liu | Aug 2014 | B2 |
8830820 | Mandal et al. | Sep 2014 | B2 |
8937961 | Vairavakkalai | Jan 2015 | B1 |
8949410 | Patel et al. | Feb 2015 | B2 |
8995272 | Agarwal et al. | Mar 2015 | B2 |
9038151 | Chua et al. | May 2015 | B1 |
9124506 | Jogalekar et al. | Sep 2015 | B2 |
9143558 | Blander et al. | Sep 2015 | B2 |
9154381 | Dutta | Oct 2015 | B2 |
9191139 | Venkata et al. | Nov 2015 | B1 |
9243558 | Samara-Rubio | Jan 2016 | B2 |
9444842 | Porras et al. | Sep 2016 | B2 |
9450817 | Bahadur et al. | Sep 2016 | B1 |
9450823 | Arora et al. | Sep 2016 | B2 |
9467536 | Kanekar et al. | Oct 2016 | B1 |
9705783 | Jogalekar et al. | Jul 2017 | B2 |
9742648 | Saquib et al. | Aug 2017 | B2 |
9749401 | Patil | Aug 2017 | B2 |
9832269 | Prakash Usgaonkar | Nov 2017 | B2 |
9853874 | Chinthalapati et al. | Dec 2017 | B2 |
9912536 | McDaniel et al. | Mar 2018 | B2 |
20030218982 | Folkes et al. | Nov 2003 | A1 |
20070002755 | Matityahu et al. | Jan 2007 | A1 |
20070011685 | Yim et al. | Jan 2007 | A1 |
20070041332 | Jorgensen et al. | Feb 2007 | A1 |
20070153683 | McAlpine | Jul 2007 | A1 |
20110145390 | Kakadia et al. | Jun 2011 | A1 |
20120131222 | Curtis et al. | May 2012 | A1 |
20130010600 | Jocha et al. | Jan 2013 | A1 |
20130064079 | Zhang | Mar 2013 | A1 |
20130094350 | Mandal et al. | Apr 2013 | A1 |
20130124707 | Ananthapadmanabha et al. | May 2013 | A1 |
20130311675 | Kancherla | Nov 2013 | A1 |
20130318243 | Chinthalapati et al. | Nov 2013 | A1 |
20140075519 | Porras et al. | Mar 2014 | A1 |
20140149542 | Luo et al. | May 2014 | A1 |
20140173018 | Westphal et al. | Jun 2014 | A1 |
20140280817 | Uppalapati et al. | Sep 2014 | A1 |
20140280893 | Pfeifer et al. | Sep 2014 | A1 |
20150043382 | Arora et al. | Feb 2015 | A1 |
20150071108 | Lumezanu et al. | Mar 2015 | A1 |
20150103642 | Stuart | Apr 2015 | A1 |
20150195162 | Gandham et al. | Jul 2015 | A1 |
20150215156 | Yoon | Jul 2015 | A1 |
20150256397 | Agarwal | Sep 2015 | A1 |
20150304158 | Dharmadhikari et al. | Oct 2015 | A1 |
20150319190 | Kruglick | Nov 2015 | A1 |
20150334002 | Jogalekar et al. | Nov 2015 | A1 |
20150350077 | Durrani et al. | Dec 2015 | A1 |
20150358338 | Zeitlin et al. | Dec 2015 | A1 |
20160043941 | D'Heureuse et al. | Feb 2016 | A1 |
20160112514 | Prakash Usgaonkar | Apr 2016 | A1 |
20160156550 | Song | Jun 2016 | A1 |
20160182336 | Doctor et al. | Jun 2016 | A1 |
20160191545 | Nanda et al. | Jun 2016 | A1 |
20160205071 | Cooper et al. | Jul 2016 | A1 |
20160226701 | Luo et al. | Aug 2016 | A1 |
20160226742 | Apathotharanan et al. | Aug 2016 | A1 |
20160285729 | Chinthalapati et al. | Sep 2016 | A1 |
20160285750 | Saquib et al. | Sep 2016 | A1 |
20160294731 | McDaniel et al. | Oct 2016 | A1 |
20160344471 | Meng et al. | Nov 2016 | A1 |
20160344621 | Roeland et al. | Nov 2016 | A1 |
20170013049 | Patil | Jan 2017 | A1 |
20170041209 | Joshi et al. | Feb 2017 | A1 |
20170048312 | Moyer | Feb 2017 | A1 |
20170104622 | Sawal et al. | Apr 2017 | A1 |
20170111246 | Shaw et al. | Apr 2017 | A1 |
Number | Date | Country |
---|---|---|
103782552 | May 2014 | CN |
2014139564 | Sep 2014 | WO |
2015032027 | Mar 2015 | WO |
2016153713 | Sep 2016 | WO |
Entry |
---|
U.S. Appl. No. 61/832,655, filed Jun. 7, 2013 by Jogalekar et al. |
U.S. Appl. No. 62/089,028, filed Dec. 8, 2014 by Durrani et al. |
U.S. Appl. No. 62/005,177, filed May 30, 2014 by Durrani et al. |
U.S. Appl. No. 62/141,672, filed Apr. 1, 2015 by Sreenivasa et al. |
U.S. Appl. No. 62/191,073, filed Jul. 10, 2015 by Patil. |
U.S. Appl. No. 62/204,388, filed Aug. 12, 2015 by Moyer. |
U.S. Appl. No. 62/247,904, filed Oct. 29, 2015 by Moyer et al. |
U.S. Appl. No. 62/136,922, filed Mar. 23, 2015 by Saquib et al. |
U.S. Appl. No. 14/805,901, filed Jul. 22, 2015 by Jogalekar et al. |
U.S. Appl. No. 14/721,978, filed May 26, 2015 by Durrani et al. |
U.S. Appl. No. 14/874,055, filed Oct. 2, 2015 by McDaniel et al. |
U.S. Appl. No. 14/848,035, filed Sep. 8, 2015 by Patil. |
U.S. Appl. No. 14/918,441, filed Oct. 20, 2015 by Moyer. |
U.S. Appl. No. 14/923,738, filed Oct. 27, 2015 by Saquib et al. |
U.S. Appl. No. 14/923,769, filed Oct. 27, 2015 by Chinthalapati et al. |
PCT Patent Application No. PCT/US16/19510 filed on Feb. 25, 2016 by Eswara Chinthalapati et al. |
NonFinal Office Action dated Nov. 18, 2016; U.S. Appl. No. 14/805,901; (9 pgs.). |
Extended EP Search Report for EP Appln. No. 16001306.6 dated Dec. 6, 2016, 10 pages. |
NonFinal Office Action dated Mar. 24, 2017; U.S. Appl. No. 14/721,978; (31 pgs.). |
Notice of Allowance dated Mar. 29, 2017; U.S. Appl. No. 14/805,901; (16 pgs.). |
NonFinal Office Action dated Apr. 21, 2017; U.S. Appl. No. 14/923,769; (58 pgs.). |
Notice of Allowance dated Apr. 27, 2017; U.S. Appl. No. 14/923,738; ( 40 pgs.). |
NonFinal Office Action dated Jun. 5, 2017; U.S. Appl. No. 14/874,055; (45 pgs.). |
Notice of Allowance for U.S. Appl. No. 14/848,035, dated Jul. 14, 2017, 43 pages. |
Hommes: “Fault Detection and Network Security in Software-Defined Networks with Openflow”; PhD Dissertation; PhD-FSTC-2014-06; The Faculty of Sciences, Technology and Communication; Mar. 25, 2014; 130 pages. |
http://www.juniper.net/documentation/en_US/junos14.2/topics/example/cos-based-forwarding-example-cos-config-guide.html; 3 pages; dated Oct. 17, 2014. |
http://www.cisco.com/c/en/us/td/docs/ios/12_0s/feature/guide/gscbts.html; 56 pages; Aug. 8, 2007. |
http://blog.hoff.geek.nz/tag/cos-based-forwarding/; 16 pages; dated Feb. 26, 2014. |
Adrichem et al.: “Fast Recovery in Software-Defined Networks”, EWSDN, 2014, 6 pages. |
Kempf et al.: “Scalable Fault Management for OpenFlow”, ICC, IEEE 2012, 5 pages. |
Tilmans: “Robust fault-recovery in Software-Defined Networks”, Ecole Polytechnique de Louvain, Masters Thesis, 2013-2014, 104 pages. |
International Search Report & Written Opinion for PCT Application PCT/US16/19510 dated May 25, 2016, 13 pages. |
OpenFlow Switch Specification, Version 1.5.0, Open Networking Foundation, Dec. 19, 2014, 277 pages. |
Akyildiz et al.: “A roadmap for traffic engineering in SDN-Openflow networks”, Computer Networks, vol. 71, Jun. 19, 2014, 30 pages. |
Soeurt et al, Shortest path forwarding using OpenFlow, University of Amsterdam, 58 pages, Feb. 2012. |
Egilmez et al., OpenQoS: An OpenFlow Controller Design for Multimedia Delivery With End-to-End Quality of Service Over Software-Defined Networks, IEEE, 8 pages, 2012. |
Zartash Afzal Uzmi, Markus Nebel, Ahsan Tariq, Sana Jawad, Ruichuan Chen, Aman Shaikh, Jia Wang, and Paul Francis, “SMALTA: Practical and Near-Optimal FIB Aggregation,” Pulished in: Proceedings of the Seventh Conference on emerging Networking Experiments and Technologies. Tokyo, Japan, Dec. 6-9, 2011. Article No. 29, 12 pages. |
Christian E. Rothenberg, Marcelo R. Nascimento, Marcos R. Salvador, Carlos N.A. Correa, Sidney c. de Lucena, and Robert Raszuk, “Revising Routing Control Platforms with the Eyes and Muscles of Software-Defined Networking.” HotSDN'12, Aug. 13, 2012, Helsinki, Finland. pp. 13-28. |
Marcelo Ribeiro Nascimento, Christian Esteve Rothenberg, Marcos Rogerio Salvador and Mauricio Ferreira Magalhaesy, “QuagFlow: Partnering Quagga with OpenFlow”, SIGCOMM'10, Aug. 30-Sep. 3, 2010, New Delhi, India, 2 pages. |
Paul Zimmerman, “OpenDaylight Controller: Binding-Independent Components”, Mar. 23, 2013, 16 printed pages. Available online: https://wiki.opendaylight.org/index.php?title=OpenDaylight_Controller:Binding-Independent_Components&oldid=331. |
Paul Zimmerman, “OpenDaylight Controller: Binding Aware Components”, Mar. 23, 2013, 10 printed pages. Available online: https://wiki.opendaylight.org/index.php?title=OpenDaylight_Controller:Binding_Aware_Components&oldid=339. |
Ivan Pepelnjak, “Hybrid OpenFlow, the Brocade Way”, Jun. 19, 2012, 3 printed pages. Available online: http://web.archive.org/web/20130514054903/http://blog.ioshints.info/2012/06/hybrid-openflow-brocade-way.html. |
Port Mirroring with Linux Bridges; Waldner; Jun. 17, 2014. |
NonFinal Office Action dated Dec. 13, 2017; U.S. Appl. No. 14/918,441; (53 pgs.). |
Notice of Allowance for U.S. Appl. No. 14/923,769 dated Oct. 20, 2017, 20 pages. |
Final Office Action dated Nov. 9, 2017; U.S. Appl. No. 14/721,978; (24 pgs.). |
Notice of Allowance for U.S. Appl. No. 14/874,055 dated Nov. 15, 2017, 13 pages. |
Matt Gillies: “Software Defined Networks for Service Providers: A Practical Approach”; Cisco Connect Presentation slides dated May 13, 2013; Toronto, Canada; 68 printed pages. Available online: http://www.cisco.com/c/dam/glogal/en_ca/assets/ciscoconnect/2013/assets/docs/sdn-for-sp-mgillies.pdf. |
Number | Date | Country | |
---|---|---|---|
20170324809 A1 | Nov 2017 | US |
Number | Date | Country | |
---|---|---|---|
62191073 | Jul 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14848035 | Sep 2015 | US |
Child | 15660744 | US |