Next Article in Journal
Reinforcement Learning Based Query Routing Approach for P2P Systems
Previous Article in Journal
Secure WiFi-Direct Using Key Exchange for IoT Device-to-Device Communications in a Smart Environment
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

An Efficient Dynamic Load Balancing Scheme Based on Nash Bargaining in SDN

School of computer and information engineering, Tianjin Chengjian University, Tianjin 300384, China
*
Author to whom correspondence should be addressed.
Future Internet 2019, 11(12), 252; https://0-doi-org.brum.beds.ac.uk/10.3390/fi11120252
Submission received: 29 October 2019 / Revised: 26 November 2019 / Accepted: 4 December 2019 / Published: 5 December 2019

Abstract

:
Static multi-controller deployment architecture cannot adapt to the drastic changes of network traffic, which will lead to a load imbalance between controllers, resulting in a high packet loss rate, high latency, and other network performance degradation problems. In this paper, an efficient dynamic load balancing scheme based on Nash bargaining is proposed for a distributed software-defined network. Firstly, considering the connectivity of network nodes, the switch migration problem is transformed into a network mapping relationship reconstruction problem. Then, we establish the Nash bargaining game model to fairly optimize the two contradictory goals of migration cost and load balance. Finally, the model is solved by an improved firefly algorithm, and the optimal network mapping state is obtained. The experimental results show that this scheme can optimize the migration cost and load balance at the same time. Compared with the existing research schemes, the migration process of the switch is optimized, and, while effectively balancing the load of the control plane, the migration cost is reduced by 14.5%.

1. Introduction

The Software-Definition Network (SDN) [1] is an innovative network architecture. Its core technology, OpenFlow, separates the network control plane from the data plane, enabling flexible centralized control of distributed forwarding devices and providing an excellent platform for the creation of core networks and applications. With the increasing demand of the network, a large amount of data traffic is sent from a forwarding device, such as a switch, to the control plane. Traditional single-controller architecture is constrained by its own performance and capacity. It faces significant challenges in network security, reliability, and robustness [2,3]. Therefore, industry proposes to establish a multi-controller architecture with logically centralized physical distribution based on the original single-controller architecture [4]. This architecture requires multiple controllers to be deployed on the control plane and divide the appropriate subdomain for each controller. Each controller is responsible for centrally managing switches in its domain. Multiple controllers cooperate with each other to achieve efficient network management [5,6,7,8,9]. However, multi-controller deployment is a static network architecture. Switches and controller nodes form a fixed network topology, which cannot adapt to the dynamic changes of network traffic. If the switching traffic in the domain increases or decreases sharply in a specific period of time, the load difference between controllers will be huge, which will cause a load imbalance of the multi-controller network architecture, resulting in a high packet loss rate, high latency, low throughput, and other network performance degradation problems.
Load imbalance issues severely impact the performance of an entire network. Therefore, in recent years, the load balancing problem of the SDN multi-controller has become a research hotspot. Fu et al. [7] proposed a multi-controller sleep model for software-defined networks, allowing some controllers to enter a sleep state under light load conditions to save system costs. Following the introduction of OpenFlow 1.3 [10], Dixit et al. [11] proposed an elastic distributed network architecture for the first time, changing the mapping relationship between the controllers and switches through switch migration to implement controller load transfer of the OpenFlow standard. As an elastic flow control solution, switch migration can effectively balance the load imbalance network. Based on this idea, Yao et al. [12] proposed to migrate the switch to the controller with the lowest resource utilization to achieve load balancing. Zhang et al. [13] proposed an online load balancing method, which describes the load balancing problem as an optimization problem that minimizes the control plane’s response time. Because the migration process depends on the actual response time, the scheme can be implemented online.
The above studies are all based on choosing a suitable switch from the overload controller to migrate to the light-load controller to achieve load balancing. Although this method reduces the number of migrations, it easily causes load oscillations. Zhou et al. [14] proposed a switch group-based SDN multi-controller load balancing mechanism. This mechanism chooses a group of switches to reduce the load of the overload controller to an average level and then considers the load and delay factors of the light-load controller and transfers multiple switches to the appropriate controllers. This method not only balances the load between controllers but also solves the problem of load oscillation. Mohanasundaram et al. [15] proposed game theoretic switch-controller mapping with traffic variations in software-defined networks, describing the problem as a Markov decision process, reducing frequent migration between controllers and obtaining a stable mapping relationship. Wang et al. [16] proposed a switch migration-based decision-making scheme, which considered the load balancing degree and migration cost and achieved a compromise between the two performance indicators. Since the dimensions of the two performance indicators are not consistent, it is impossible to obtain the same degree of optimization. The authors in [17] proposed a heuristic approach considering the benefits of the immigration and outmigration controllers. Liu et al. [18] proposed a load balancing scheme based on multi-objective optimization for a software-defined network. Using a multi-objective genetic algorithm based on NSGA-II, two conflicting objectives (i.e., the load balancing degree of the control plane and the communication overhead caused by switch migration) were optimized simultaneously to obtain a high-quality and wide Pareto frontier. However, the genetic algorithm has weak convergence and can only obtain a set of non-inferior solutions. This previous article does not suggest how to choose the optimal solution.
According to the current research, switch migration as an elastic control scheme can effectively solve the problem of the unbalanced load distribution of controllers in a network. By moving the switch managed by the overload controller to the light-load controller, the dynamic load adjustment of the controllers can be realized. However, in the research on switch migration, most of the schemes still have the following problems:
  • Although the existing switch migration schemes can dynamically adjust the controller load, in the process of switch migration, network performance and migration cost are not fully considered, resulting in low migration efficiency and easily leading to the rigidity of the selection of the target controller. At the same time, the high complexity migration algorithm and multi-switch migration conflict also reduce the resource utilization of the controller.
  • The migration strategy is too idealized to consider the connectivity between the network’s topological nodes, and the influence of isolated nodes on network performance is neglected.
  • Based on the above multi-objective optimization problem, it is impossible to weigh the contradictory goals fairly, and the multi-objective intelligent optimization algorithm cannot obtain the optimal solution.
This paper proposes an efficient load balancing scheme based on Nash bargaining (LBSNB). Firstly, the switch migration problem is equivalent to the network remapping problem. Based on the Nash bargaining game model, two contradictory indicators, load balance degree and migration cost, are modeled and the connectivity between network devices is considered to build the policy set, which prevents an idealized reconstruction state. Then, an improved firefly algorithm is proposed to solve the model. Finally, experiments are carried out based on simulated scenarios and compared with other optimization algorithms. The experimental results show that the proposed algorithm can fairly balance the load balancing degree and migration costs and can quickly obtain a Pareto optimal solution, which verifies the effectiveness of the proposed strategy.
The rest of the paper is organized as follows: Section 2 presents the model and the problem formulation of switch migration. The LBSNB schemes proposed in this paper are explained in Section 3. In Section 4, the optimization algorithm for solving the model is proposed. In Section 5, multiple scenarios, experiments, and analyses are carried out. Finally, we conclude the paper and suggest future work in Section 6.

2. Analysis and Modeling

In this section, we illustrate the problem of controller load imbalance in the process of multi-controller deployment in a distributed network and demonstrate that node connectivity is an essential factor that cannot be ignored in switch migration. Then, based on the connectivity of the network nodes, the load balance degree and migration cost of the network reconstruction are analyzed and modeled, and the parameter definitions and related calculations are given.

2.1. Problem Analysis

SDN is a new network architecture with programmable functions and a separate forwarding plane and control plane. It is mainly divided into three layers: the data layer, the control layer, and the application layer. Based on the three-tier architecture of the SDN, the controller can control and manage the SDN switch through the South interface (such as the OpenFlow protocol [19]) and provide programmable support to the application layer through the north interface.
The OpenFlow protocol provides more solutions for controller load imbalance. The OpenFlow protocol is a standard protocol used for the interaction information between the controller and the SDN switch. The general OpenFlow 1.3 protocol presently supports three message types: controller-switch message (such as Role-Request), asynchronous message (such as Packet-In), and symmetric message (such as Echo request). At the same time, OpenFlow requires that the controller has three roles for each switch: equal, master, and slave [20]. The default role of the controller is equal. Controllers in the equal role can receive all asynchronous messages from the switch. The controller can request to be a slave through Role-Request. The slave controller can only read the connected switch (i.e., read-only). The controller can also request to assume the master role of the switch. The controller with the master role is similar to the equal role controller and can fully access the switch. However, the switch guarantees that only one controller in the master role can be connected.
The definition of the three roles of the controller in OpenFlow ensures the security of the network. Once the master controller fails or overloads, the managed switch can be migrated to the slave controller to avoid controller outages. As shown in Figure 1, the traffic in control domain 2 surges, causing controller c 2 to be the overload controller. Based on the idea of switch migration, switch s 6 in control domain 2 can be migrated to the slave controller (i.e., c 1 , c 3 , and c 4 ). However, s 6 is not connected to all intra-domain switches in control domain 4. In fact, the migration of s 6 to c 4 is only the ideal situation, as it is impossible to achieve migration in a real network. Therefore, considering the connectivity between the actual network topology nodes, switch s 6 can only be migrated to slave controller c 1 or c 3 .
How to choose the optimal network remapping state based on the connectivity of nodes is the critical problem to be solved in this paper. It is assumed that after the two performance indicators of load balancing and migration cost are optimized according to the algorithm in this paper, the overload controller c 2 chooses s 6 to migrate to controller c 1 to relieve its load pressure. Controller c 2 first installs flow rules to s 6 , and then s 6 forwards migration requests to controller c 1 through s 2 . Finally, c 1 accepts the migration request, changes the slave role to master, and the main controller of s 6 is converted from c 1 to c 2 to complete the migration operation.

2.2. Model Construction

The multi-controller network generally adopts the in-band communication mode [21]—that is, the switch and the controller are deployed at the same node, and the control flow and the data flow are transmitted using the same channel. According to the relevant knowledge of graph theory, SDN is modeled as an undirected graph G = { V , E } . In network G , V represents the set of controllers and switch nodes, and E represents the set of links between the nodes. Suppose there are M controllers in the network; the controller set is represented as C = { c 1 , c 2 , , c M } , and the capacity is ω i . There are N switches, and the switch set is represented as S = { s 1 , s 2 , , s N } . Each controller and its managed switches form a subdomain, and controllers between different domains communicate with each other and share the same network view. Moreover, each switch in the network has only one master controller and any slave controller. In order to clearly describe the network model, the network topology corresponding to Figure 1 is given below, as shown in Figure 2.
Detailed descriptions of the main parameters are shown in Table 1.
In order to explain the migration process of the switch in detail, the related parameters in the network are defined as follows.
Definition 1.
Mapping matrix. The connection relationship between the controller and the switch in the domain is defined as the mapping matrix—i.e., X = [ x k i ] M × N , where x k i = 1 means that switch s k is managed by the controller c i , x k i = 0 means that it is not managed by c i ; moreover, a switch can only be managed by one controller, so it satisfies i = 1 M x k i = 1
Definition 2.
Node connectivity. The connection between two nodes is denoted as Λ = [ a i j ] M × N , where a i j = 1 means that there is a connection relationship between nodes s i and s j . If a i j = 0 , the two nodes do not have a connection relationship.
The purpose of switch migration is to balance the load on the control plane effectively. However, switch migration can also produce high migration costs. Therefore, this paper focuses on load balancing and migration cost issues after network remapping. Next, the two performance indicators are described in detail.

2.2.1. Load Balancing Degree

When an unknown flow enters the switch, it needs to send PACKET-IN messages to the controller to query the forwarding policy. The controller responds to the switch request, delivers the flow table items, and installs a new routing rule to the switch. The controller load is mainly composed of maintenance management domain information, flow table installation, and inter-domain controller synchronization overhead.

Maintaining management domain information overhead

In SDN network architecture, distributed controllers manage switches centrally. In order to maintain global network information, controllers need to communicate with switches periodically to collect information such as traffic and the hops of switches in their management domain. As shown in Equation (1), the traffic required to maintain the management domain is related to the polling switch speed, the connection relationship between switches and controllers, and the number of hops between devices.
Ψ c i = k = 1 N υ x k i d k i
Among them, Ψ c i denotes the traffic required by controller c i to maintain the management domain, υ denotes the average rate of the controller polling switch in the control domain, x k i denotes the connection relationship between switch s k and controller c i , and d k i denotes the hops between device k and i .

Flow table installation overhead

When a new flow arrives at the switch, the switch sends a flow request to the controller. The controller formulates the flow table rule according to the flow request and delivers the rule to the corresponding switch. The generated flow table installation overhead is shown in Equation (2),
ϒ c i = k = 1 N λ k x k i d k i
where ϒ c i represents the flow table installation cost generated by controller c i , and λ k represents the flow request rate of switch s k .

Inter-domain controller synchronization overhead

When the data flows through different control domains, the controllers need to perform state synchronization to maintain the consistency of the SDN global network view. The inter-domain controller synchronization overhead generated by this process is shown in Equation (3),
Γ c i = c i , c j C τ d i j
where Γ c i represents the inter-domain controller synchronization cost of controller c i , and τ represents the average rate of polling the controller, because the controller does not synchronize all the information of the switch, so it satisfies τ < υ .
The load of controller c i is a linear addition of the above three parts, as shown in Equation (4).
L c i = Ψ c i + ϒ c i + Γ c i
The average load of the controller is shown in Equation (5).
L ¯ = 1 M i = 1 M L c i
In statistics, the coefficient of variation is usually used to characterize the degree of dispersion between data, expressed as the ratio of the standard deviation of the data to the mean, which is a normalized measure of the degree of the dispersion of the probability distribution. Therefore, the coefficient of variation is used in SDN to measure the load balancing degree of the controller, as shown in Equations (6) and (7),
σ = 1 M i = 1 M ( L c i L ¯ ) 2
L B D = ( 1 σ L ¯ ) × 100 %
where σ is the standard deviation and L B D is the load balancing degree. The larger the L B D value, the more balanced the load.

2.2.2. Migration Cost

Although switch migration can effectively balance the load, it inevitably produces an additional migration overhead. The overload controller issues a migration command to the intra-domain switch and installs the migration rule to the switch to be migrated. Then the switch forwards the rule to the target controller through the devices of other management domains to issue a migration request. The switch migration cost generated by this process is mainly composed of the switch communication cost and the migration request cost.
1. Switch communication cost
The communication cost of the switch mainly refers to the normal communication cost generated by the data to be migrated by the switch through the devices in different domains reaching the target controller. The communication cost of the switch can be expressed as:
p s k c o m = θ [ ( k = 1 N x k i d k i ) + ( k = 1 N x k j d k j ) ] .
where θ represents the average transmission rate of the switch communication, d k i represents the hop count between the switch s k to be migrated and the overload controller c i , and d k j represents the hop count between the switch s k to be migrated and the target controller c j .
2. Migration request cost
The cost of sending migration requests through the shortest path to the radial target controller is mainly related to the minimum hops, data transmission rate between the switch to be migrated and the target controller, as shown in Equation (9),
p s k r e q = θ ( k = 1 N x k i + k = 1 N x k j ) ( min d k j ) .
where min d k j represents the minimum hop count between the switch s k to be migrated and the target controller c j .
The switch migration cost is a linear sum of the switch communication cost and the migration request cost and is represented as
p s k = p s k c o m + p s k r e q .
The migration cost of the SDN control plane may be composed of the migration cost of multiple switches, which is expressed as the cost of changing the mapping state between the switch and the controller to a better network topology state. If the adjusted network mapping relationship is X = [ x k i ] M × N , then the total cost of the network from state X = [ x k i ] M × N to X = [ x k i ] M × N is
C o s t = k = 1 N m k p s k .
where m k denotes whether the switch s k has migrated and satisfies
m k = { 0 x k i = x k j = 1 , a n d   i = j 1 x k i = x k j = 1 , a n d   i j
To change the network mapping relationship through switch migration and promote the scalability of the control plane, we need to optimize the performance of two aspects: on the one hand, to improve the controller load balance; on the other hand, to reduce the switch’s migration cost. Since these are two conflicting goals, optimizing one of these goals will inevitably impair the performance of the other. Based on this, a multi-objective model can be expressed as
{ max L B D min C o s t
L j δ j ω j ;   1 j M
x k j { 0 , 1 } ;   1 k N , 1 j M
j = 1 M x k j = 1 ;   s k S
where δ j indicates the threshold factor of controller c j . The constraint condition (14) indicates that the load of each controller must not exceed the threshold after the switch is migrated; constraint condition (15) indicates the mapping relationship after the switch is migrated; constraint (16) indicates that a switch can only have one master controller.

3. Multi-Objective Decision Making Based on Nash Bargaining

There are two commonly used methods for solving multi-objective optimization problems. The first is to set weights for each sub-goal, converting the problem into an aggregate function by a specific mathematical approach, and the second is to transform a multi-objective problem into a single-objective problem [22,23]. However, the dimensions and magnitudes of the various objectives may not be the same. It is difficult to set reasonable weights for each goal based on experience. That is, a fair compromise between the two contradictory goals cannot be achieved. The second is to use an intelligent optimization algorithm to determine the optimal solution [24]. This method obtains an approximate optimal non-inferior solution set and cannot acquire an accurate optimal solution. Therefore, the Nash bargaining game method was introduced. The Nash bargaining game is a classic cooperative game. It no longer needs to set weights for each goal. Each goal has equal importance. The Nash bargaining game focuses on collective rationality and fairness and can determine the Pareto optimal value. It is a useful mathematical tool for studying competitive or conflicting problems and provides a new solution for multi-objective optimization problems.

3.1. Nash Bargaining Model

Nash proposed to use the Nash bargaining model to solve the cooperative game problem [25]. Firstly, different targets are regarded as different players, and the initial strategy and the income functions are set. Each player party continuously negotiates and negotiates in the policy space and finally obtains a Nash equilibrium solution. This solution has Pareto validity, equivalent income invariance, and irrelevant selection independence [26]. Nash uses the Nash product to represent global benefits and proves that the largest solution of the Nash product is the Nash equilibrium solution, which falls on the Pareto frontier and can achieve fairness and global optimization for multiple targets.
The mathematical expression of game g is as follows: Suppose g has m game players, i.e., p 1 , p 2 , , p m , and all the alternative strategies of each game player in the strategy space are called the strategy set, i.e., s 1 , s 2 , , s m . The gain function obtained by the player according to the selected strategy is expressed as u 1 , u 2 , , u m . Then, the game can be expressed as g = { p 1 , p 2 , , p m ; s 1 , s 2 , , s m ; u 1 , u 2 , , u m } .
Switch migration can be viewed as a remapping of the connection between the switch and the controller in the network. In an actual network, the switch does not form a mapping relationship with all controllers. If the connectivity between the node devices is not considered, the new mapping relationship obtained can only be an ideal state. Based on the above considerations, the remapping of the switch (that is, the policy set) needs to satisfy the connectivity constraint, as shown in Equation (17),
x k j = { 0   or   1 s = 1 N x k i a k s x k j > 0 0 s = 1 N x k i a k s x k j = 0
where x k j is the original mapping relationship between switch s k and controller c j , and x k j is the mapping relationship after network remapping. If switch s k in the management domain of controller c i has connectivity with any switch s s in the management domain of controller c j , then switch s k can form a new connection relationship with controller c j (that is, x k j = 1 ) or maintain the original mapping relationship (i.e., x k j = 0 ). If there is no connectivity, switch migration cannot be achieved (that is, x k j can only be taken as 0).
In this paper, the load balancing degree and migration cost are regarded as two players. L B D and C o s t are the gain functions of these two players, respectively. The possible mapping relationship between the switch and controller is used as the strategy space of both sides of the game, and the Nash bargaining game model is established, as shown in Formulas (18)–(23),
max   ( L B D - a L B D ) ( C o s t - a c o s t )
L j δ ω j ;   1 j M
x k j = { 0   or   1 s = 1 N x k i a k s x k j > 0 0 s = 1 N x k i a k s x k j = 0
j = 1 M x k j = 1 ;   s k S
a L B D L B D
a C o s t C o s t
where a L B D and a C o s t are the bargaining breakdown points for the load balance and the migration cost, respectively, i.e., the worst possible return for both sides of the game. The goal of the game is to achieve a game agreement at least at this breakpoint.
In the game process, each game player will tend to change their own breakpoint to improve their own income. If there is no restriction on this selfish behavior, each player will continuously change the breakpoint value, causing the bargaining to fail. In order to avoid bargaining failure, it is necessary to establish a bargaining agreement for the players to make the game fair and orderly. Under the premise of following the agreement, the game players find the optimal breakpoint of the negotiation through multiple games, and then obtain the maximum benefit from both sides of the game, namely the optimal value of the load balancing degree and migration cost.

3.2. Fair Bargaining Agreement

The fair bargaining agreement is mainly used to impose regular constraints on the initial breakpoint of the bargaining and the update of the bargaining point.

3.2.1. Initial bargaining breakpoint

At the beginning of the game, the initial bargaining breakpoint needs to be set for the game player, and the breakpoint can also be considered the minimum performance threshold for load balancing and migration costs. The optimal and worst load balance degree ( L B D b e s t , L B D w o r s t ) is easily obtained according to Formula (4), and the optimal and worst migration cost ( C o s t b e s t , C o s t w o r s t ) is obtained according to Formula (10). Therefore, the worst target of load balancing and migration cost is taken as the bargaining point ( L B D w o r s t , C o s t w o r s t ) , and the bargaining game is performed based on the minimum performance threshold.

3.2.2. Update of the bargaining breakpoint

In order to prevent the game players from unrestrictedly changing their own bargaining breakpoints to obtain the maximum benefit of selfish behavior, an updated agreement must be followed for each game player. That is to say, when the players renew their breakdown point, the change of the breakdown point is, at most, half of the difference between the current revenue and the previous breakdown point. The updated rules for the bargaining point are as follows:
a L B D k a L B D k 1 + 1 2 ( L B D k 1 a L B D k 1 ) ,
a C o s t k a C o s t k 1 + 1 2 ( C o s t k 1 a C o s t k 1 ) .
Among them, a L B D k and a C o s t k are the bargaining breakpoints of the load balance degree and migration cost in the kth iteration process.

4. Model Solving

The multi-objective decision-making method based on Nash bargaining proposed in this paper belongs to the non-convex nonlinear optimization problem with multiple constraints. It is complicated to solve with traditional mathematical methods and is not suitable for large-scale SDN networks. Emerging intelligent optimization algorithms, such as the genetic algorithm, simulated annealing algorithm, and particle swarm optimization algorithm, have shown good optimization computing power and have been widely used in the computer field. In this paper, the firefly algorithm is used to solve the model. The firefly algorithm [27] is a stochastic nonlinear global search algorithm with strong global search ability and high precision. Compared to the heuristic algorithm described above, the firefly algorithm has a simple structure and fewer parameters. Moreover, its parameters have less influence on the algorithm, and the algorithm is easy to implement.
Considering that, in a large-scale network structure, the application of the genetic algorithm, particle swarm optimization, and other heuristic algorithms requires a very long running time and a large storage space, it is necessary to find a simple and easy to implement algorithm to solve the nonlinear optimization problem with multiple constraints. The firefly algorithm has a fast global search ability and does not depend on parameter settings, so it is easy to implement on a computer. Therefore, it is suitable for solving the model in this paper.

4.1. The Basic Firefly Optimization Algorithm

The firefly algorithm is a bionic optimization algorithm. Its principle is to simulate firefly individuals with points in the search space. Each individual has brightness and attractiveness. Because of the phototaxis characteristics of fireflies, fireflies move towards brighter individuals. The core is used to keep fireflies close to brighter individuals by continually updating their positions. Combined with the SDN load balancing problem, the mapping relationship between the switch and controller in the strategy space is considered to be the location of a firefly, and the objective function of the Nash bargaining game is regarded as the brightness of the firefly. Individuals with low brightness will move to individuals with high brightness, and the process of firefly movement is the process of target optimization. The brightness of each firefly is expressed as follows: I ( x i )   = ( L B D - a L B D ) ( c o s t - a c o s t ) , I ( x i ) is the brightness of the i-th firefly, x i is the position of the i-th firefly, and d is the dimension of the problem.
If the brightness of firefly i is greater than the brightness of firefly j , firefly j is attracted by i . The formula for calculating the attractiveness of i to j is as follows:
α i j = α max e λ r i j 2 .
where α max is the maximum attractive force, λ is the light absorption coefficient, and r i j is the Cartesian distance between firefly i and firefly j —i.e., r i j = x i x j = k = 1 d ( x i k x j k ) 2 .
Firefly j is attracted by i and moves to i . The position update formula is as follows:
x j k = x j k 1 + α i j ( x i k 1 x j k 1 ) + ϑ ε j .
where x j k is the position of firefly j during the kth iteration, ϑ ε j is a random disturbance term, ϑ is a constant, and ε j is a random number obtained by uniform distribution.

4.2. Improved Algorithm

Although the firefly algorithm shows good performance advantages in global optimization, it also has some shortcomings; for example, it is premature and can easily fall into the local optimum. In this paper, chaos theory and the elite retention strategy are introduced to improve the traditional firefly algorithm.

4.2.1. Chaos Theory

Chaos is a kind of non-linear phenomenon in nature, which has the characteristics of randomness and non-periodicity. Logistic mapping is a classic model for studying chaotic systems. This model can traverse all states without repeating within a certain range. Therefore, this paper introduces the Logistic map in chaos theory into the firefly optimization algorithm and optimizes the random disturbance parameter ε j . This method can improve the premature phenomenon and improve the global optimization ability. The mathematical expression of the Logistic iterative process is as follows:
x k = u x k 1 ( 1 x k 1 ) .
The improvement of ε j is as follows:
ε j k = u ε j k 1 ( 1 ε j k 1 ) .
Set the chaos parameter u = 4 ,and ε j [ 0 , 1 ] . Logistic mapping generates a random function during each iteration. This process implements dynamic control of the parameters and improves the global search capability of the firefly algorithm.

4.2.2. Elite Strategy

In order to prevent the Pareto optimal solution from being lost, the elite retention strategy in the genetic algorithm is used to retain the optimal solution during each iteration, and then the firefly individual in the next iteration is replaced by the optimal solution to ensure that the optimal solution is not lost and speeds up the convergence. The specific steps are as follows:
  • Initialize the parameters;
  • Initialize the firefly position on the premise of satisfying the constraint;
  • Initialize the corresponding brightness I according to the objective function;
  • Save the optimal solution C e l i t e that maximizes brightness;
  • Update the firefly position, increasing the number of iterations by one;
  • Replace the worst individual with C e l i t e ;
  • Calculate the corresponding brightness I according to the objective function;
  • Check whether the maximum number of iterations is reached. If the maximum number of iterations is reached, the search ends; otherwise, go to step 4.

4.3. SDN Network Reconstruction Algorithm

By balancing the control plane load through switch migration, the mapping between the switch and the controller is inevitably reconstructed. In order to optimize network performance, a new mapping relationship needs to be found to optimize the load balancing and migration costs. According to this idea, the Nash bargaining model is established. Combining the Nash bargaining game process and the optimization mechanism of the firefly algorithm, the optimal strategy for the game players is solved, and the Pareto optimal solution is obtained. The specific optimization process is shown in Algorithm 1.
Algorithm 1 LBSNB
Input: The network topology G = { V , E } ;
   The original network mapping matrix X ;
   The flow request rate of the switch λ k ;
   The number of hops between devices d k i ;
   The controller capacity ω i ;
   The maximum number of iterations I i t e r .
Output: The new network mapping matrix X
1: Initialize the number of the firefly populations, the maximum number of iterations, and the associated parameters r and ε j .
2: Randomly generate an initial feasible strategy in the game strategy set to initialize the firefly position x i .
3: Initialize the bargaining breakpoints a L B D and a C o s t .
4: The corresponding firefly brightness I ( x i ) is determined according to the objective function of the game model, and the individual C e l i t e with the highest brightness is saved.
5: The firefly position is updated according to chaos theory and Formula (27).
6: Calculate the brightness of each firefly after the location update and replace the worst-case individual with C e l i t e .
7: Determine whether the difference between the highest and worst brightness is less than the constant ζ and, if so, update the bargaining breakpoint according to Equations (24) and (25); otherwise, perform Steps 4–7.
8: The termination condition is judged. If the maximum number of iterations is reached, the loop is ended, and the optimal firefly position is output; otherwise, Step 4 is continued.

5. Simulation Experiment

5.1. Simulation Environment Settings

5.1.1. Experiment platform

In order to verify the adaptability of this method to different scales of networks, the experiment is carried out on a PC with an Intel Core i7 CPU at 3.4 GHz with 8 GB of RAM, using the North American Internet 2 OS3E [28] and Columbus [29] network topologies. OS3E has 34 nodes and 42 links, while Columbus has 70 nodes and 85 links. This experiment uses OpenDaylight as the controller, performs simulation experiments on the Mininet, and uses the Cbench [30] tool to measure the maximum rate at which the controller processes the stream request.

5.1.2. Parameter settings

According to the traffic characteristics, the traffic generator is used to simulate real network traffic. The average flow generation rate is 250 KB/s, the polling switch rate υ = 25   K B / s , the average communication rate θ = 20   K B / s , the polling controller rate τ = 10   K B / s , and the threshold factor δ j is set to 0.8. The parameters of the firefly algorithm are set as follows: the value of the maximum attraction α max is 1, the light absorption coefficient meets λ [ 0.01 , 100 ] , and the range of step factor ϑ is ϑ [ 0 , 1 ] . The higher the step factor, the stronger the global search ability, which will, however, reduce the convergence accuracy. The step factor is generally set to 0.4, and ε j is a random number obeying uniform distribution on [ 0 , 1 ] . The maximum number of iterations is I i t e r = 500 , and the constant ζ is set to 0.01.

5.2. Simulation Environment Settings

In order to verify the effectiveness of the Nash bargaining based load balancing scheme (LBSNB), this scheme is compared with the under-utilization migration strategy (UMS) [12] and the multi-objective optimization scheme based on multi-objective optimization (MOS) [18]. Among these models, UMS migrates the switches managed by the overload controller to the light-load controller with the lowest resource utilization. MOS uses the genetic algorithm to optimize the load balancing degree and migration cost and obtains a better mapping relationship. Moreover, the comparative performance indicators include the load balancing degree, controller response time, and migration cost.

5.2.1. Load Balancing Degree

MOS, UMS, and LBSNB are run in the two network topologies, and their load conditions are compared and analyzed. The comparison results of the load balancing degree are obtained from Formula (7), as shown in Figure 3 and Figure 4.
From the results of the load balancing of the controllers in both networks, it can be seen that when the switch request rate is low, the load balancing degree of the three algorithms is basically the same, indicating that the controller in the network does not overload. When the request rate continues to increase (300 KB/s–800 KB/s), the load balancing degree of the three algorithms shows a downward trend, indicating that the network controller begins to overload. It can be seen from Figure 3 and Figure 4 that UMS performance is the worst, MOS is second, and the algorithm is optimal. Because UMS does not quantify the migrated switch, it is easy to make the target controller’s load too high. MOS is solved based on the genetic algorithm and obtains the approximate optimal solution. The proposed algorithm can obtain a fair Pareto optimal solution based on the Nash bargaining model. When the switch request rate reaches its maximum, the load balance is the lowest, indicating that all controllers are overloaded. At this time, all three algorithms are invalid, and the controller needs to be added to relieve the load pressure.

5.2.2. Controller Response Time

The response time of the controller is an essential factor in measuring the performance of the network. Therefore, the experiment is repeated 30 times, and the average response time of the controllers of the three strategies is compared. The results are shown in Figure 5 and Figure 6.
As can be seen from Figure 5 and Figure 6, the average response time of the UMS is the largest, and its distribution is the most uneven because the migration of the switch to the controller with the lowest resource utilization does not accurately balance the control plane load. The load is unrestricted, and the target controller may be overloaded again, resulting in an extended response time for the controller. The response time of MOS and UMS is generally consistent because both strategies can effectively balance the controller load, and the balanced network does not experience controller overload.

5.2.3. Migration Cost

The cost of switch migration was compared, and the results are shown in Figure 7 and Figure 8. The migration cost of UMS is higher than that of MOS and LBSNB because it only considers resource utilization as a single factor in selecting the target controller and does not consider the migration cost. Both MOS and LBSNB strategies can maintain a short migration time and migration cost. The experimental results show that LBSNB is slightly better than MOS in terms of migration time, indicating that the firefly algorithm in this strategy is superior to the MOS genetic algorithm in optimization time. This paper’s strategy thus performs better in multi-objective optimization.

6. Conclusions

Aiming at the problem of load imbalance in distributed multi-controller architecture, a multi-objective optimization model considering load balance and migration cost is proposed using a Nash bargaining mechanism and firefly algorithm to solve the model quickly. The experimental results show that this scheme can effectively balance the controller load with less migration time, reduce the additional migration cost introduced by switch migration, shorten the controller response time, and adapt to different scales of network structures. The proposed scheme has resulted in an ideal network environment. The next study will take into account the particular situation of equipment failure in the network and offer a safer and more efficient load balancing scheme.

Author Contributions

The authors contributed equally to the preparation of the manuscript and the concept of the research. The writing of the draft was by G.L. and K.L.; the review and editing of the draft were done by Y.L. and Y.P.

Funding

This research was funded by the Natural Science Foundation of Tianjin, grant number 17JCQNJC00500, the Tianjin Educational Science Project Planning for 13th Five-year, grant number HE3045, and the Fund for Development of Science and Technology of Tianjin Education Committee, grant number 2018KJ174.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Feamster, N.; Rexford, J.; Zegura, E. The road to SDN: An intellectual history of programmable networks. ACM SIGCOMM Comput. Commun. Rev. 2014, 44, 87–98. [Google Scholar] [CrossRef]
  2. Bhaumik, P.; Zhang, S.; Chowdhury, P.; Lee, S.-S.; Lee, J.H.; Mukherjee, B. Software-defined optical networks (SDONs): A survey. Photonic Netw. Commun. 2014, 28, 4–18. [Google Scholar] [CrossRef]
  3. Xue, H.; Kim, K.T.; Youn, H.Y. Dynamic Load Balancing of Software-Defined Networking Based on Genetic-Ant Colony Optimization. Sensors 2019, 19, 311. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  4. Muthanna, A.; Ateya, A.A.; Makolkina, M.; Vybornova, A.; Markova, E.; Gogol, A.; Koucheryavy, A. SDN multi-controller networks with load balanced. In Proceedings of the 2th International Conference on Future Networks and Distributed Systems (IC-FNDS), New York, NY, USA, 26–27 June 2018. [Google Scholar]
  5. Zhao, Y.; Liu, C.; Wang, H.; Fu, X.; Shao, Q.; Zhang, J. Load balancing-based multi-controller coordinated deployment strategy in software defined optical networks. Opt. Fiber Technol. 2018, 46, 198–204. [Google Scholar] [CrossRef]
  6. Hu, T.; Yi, P.; Guo, Z.; Lan, J.; Hu, Y. Dynamic slave controller assignment for enhancing control plane robustness in software-defined networks. Future Gener. Comput. Syst. 2019, 95, 681–693. [Google Scholar] [CrossRef]
  7. Fu, Y.H.; Bi, J.; Wu, J.P.; Chen, Z.; Wang, K.; Luo, M. A dormant multi-controller model for software defined networking. China Commun. 2014, 11, 45–55. [Google Scholar]
  8. Li, G.; Wang, X.; Zhang, Z.; Chen, Y.; Liu, S. A Scalable Load Balancing Scheme for Software-Defined Datacenter Networks based on Fuzzy Logic. Int. J. Perform. Eng. 2019, 15, 2217–2227. [Google Scholar]
  9. Ros, F.J.; Ruiz, P.M. On reliable controller placements in software-defined networks. Comput. Commun. 2016, 77, 41–51. [Google Scholar] [CrossRef]
  10. Wang, H.; Zhao, Y.; Nag, A. Quantum-Key-Distribution (QKD) Networks Enabled by Software-Defined Networks (SDN). Appl. Sci. 2019, 9, 2081. [Google Scholar] [CrossRef] [Green Version]
  11. Dixit, A.; Hao, F.; Mukherjee, S.; Lakshman, T.; Kompella, R.R. ElastiCon; an elastic distributed SDN controller. In Proceedings of the 2014 ACM/IEEE Symposium on Architectures for Networking and Communications Systems (ANCS), Marina del Rey, CA, USA, 20–21 October 2014; pp. 17–27. [Google Scholar]
  12. Yao, G.; Bi, J.; Li, Y. On the capacitated controller placement problem in software defined networks. IEEE Commun. Lett. 2014, 18, 1339–1342. [Google Scholar] [CrossRef]
  13. Zhang, S.; Lan, J.; Sun, P.; Jiang, Y. Online load balancing for distributed control plane in software-defined data center network. IEEE Access 2018, 6, 18184–18191. [Google Scholar] [CrossRef]
  14. Zhou, Y.; Wang, Y.; Yu, J.; Ba, J.; Zhang, S. Load balancing for multiple controllers in SDN Based on switches group. In Proceedings of the 2017 19th Asia-Pacific Network Operations and Management Symposium (APNOMS), Seoul, Korea, 27–29 September 2017; pp. 227–230. [Google Scholar]
  15. Mohanasundaram, J.G.; Truong-Huu, T.; Gurusamy, M. Game Theoretic Switch-controller Mapping with Traffic Variations in Software Defined Networks. In Proceedings of the 2018 IEEE Global Communications Conference (GLOBECOM), Abu Dhabi, UAE, 9–13 December 2018; pp. 1–6. [Google Scholar]
  16. Wang, C.A.; Hu, B.; Chen, S.; Li, D.; Liu, B. A switch migration-based decision-making scheme for balancing load in SDN. IEEE Access 2017, 5, 4537–4544. [Google Scholar] [CrossRef]
  17. Al-Tam, F.; Correia, N. On Load Balancing via Switch Migration in Software-Defined Networking. IEEE Access 2019, 7, 95998–96010. [Google Scholar] [CrossRef]
  18. Liu, B.G.; Shu, Y.A.; Fu, Y.H. Load balancing scheme based on multi-objective optimization for software defined network. Comput. Appl. 2017, 37, 1555–1559, 1573. [Google Scholar]
  19. OpenFlow Switch Specification Version 1.4.0. Available online: https://www.opennetworking.org/ (accessed on 23 March 2018).
  20. Ren, T.; Xu, Y. Analysis of the New Features of OpenFlow 1.4. In Proceedings of the 2nd International Conference on Information, Electronics and Computer (ICIEAC), Wuhan, China, 7–9 March 2014. [Google Scholar]
  21. Akyildiz, I.F.; Wang, P.; Lin, S.-C. SoftAir: A software defined networking architecture for 5G wireless systems. Comput. Netw. 2015, 85, 1–18. [Google Scholar] [CrossRef]
  22. Liu, H.-L.; Gu, F.; Zhang, Q. Decomposition of a multiobjective optimization problem into a number of simple multiobjective subproblems. IEEE Trans. Evol. Comput. 2013, 18, 450–455. [Google Scholar] [CrossRef] [Green Version]
  23. Li, G.; Wang, X.; Zhang, Z. SDN-Based Load Balancing Scheme for Multi-Controller Deployment. IEEE Access 2019, 7, 39612–39622. [Google Scholar] [CrossRef]
  24. Akbar Neghabi, A.; Jafari Navimipour, N.; Hosseinzadeh, M.; Rezaee, A. Nature-inspired meta-heuristic algorithms for solving the load balancing problem in the software-defined network. Int. J. Commun. Syst. 2019, 32, e3875. [Google Scholar] [CrossRef]
  25. Binmore, K.; Rubinstein, A.; Wolinsky, A. The Nash bargaining solution in economic modelling. Rand J. Econ. 1986, 17, 176–188. [Google Scholar] [CrossRef]
  26. Ksentini, A.; Bagaa, M.; Taleb, T.; Balasingham, I. On using bargaining game for optimal placement of SDN controllers. In Proceedings of the 2016 IEEE International Conference on Communications (ICC), Kuala Lumpur, Malaysia, 22–27 May 2016; pp. 1–6. [Google Scholar]
  27. Wang, H.; Wang, W.; Zhou, X.; Sun, H.; Zhao, J.; Yu, X.; Cui, Z. Firefly algorithm with neighborhood attraction. Inf. Sci. 2017, 382, 374–387. [Google Scholar] [CrossRef]
  28. Internet 2 Open Science, Scholarship and Services Exchange. Available online: http://www.internet2.edu/network/ose/ (accessed on 5 March 2019).
  29. The Internet Topology Zoo. Available online: http://www.topology-zoo.org/ (accessed on 5 March 2019).
  30. Cbench. Available online: http://sourceforge.net/projects/cbench/ (accessed on 10 March 2019).
Figure 1. Multi-controller network architecture.
Figure 1. Multi-controller network architecture.
Futureinternet 11 00252 g001
Figure 2. Network topological structure.
Figure 2. Network topological structure.
Futureinternet 11 00252 g002
Figure 3. Load balancing degree in the OS3E network.
Figure 3. Load balancing degree in the OS3E network.
Futureinternet 11 00252 g003
Figure 4. Load balancing degree in the Columbus network.
Figure 4. Load balancing degree in the Columbus network.
Futureinternet 11 00252 g004
Figure 5. Average response time of the controller in the OS3E network.
Figure 5. Average response time of the controller in the OS3E network.
Futureinternet 11 00252 g005
Figure 6. Average response time of the controller in the Columbus network.
Figure 6. Average response time of the controller in the Columbus network.
Futureinternet 11 00252 g006
Figure 7. Comparison of the migration costs in the OS3E network.
Figure 7. Comparison of the migration costs in the OS3E network.
Futureinternet 11 00252 g007
Figure 8. Comparison of the migration costs in the Columbus network.
Figure 8. Comparison of the migration costs in the Columbus network.
Futureinternet 11 00252 g008
Table 1. Network parameters and description.
Table 1. Network parameters and description.
Network ParametersDescription
X Mapping matrix
Λ Connected matrix
d k i Hops between devices k and i
Ψ c i Controller c i maintains the traffic required by the management domain
ϒ c i Flow table installation overhead generated by controller c i
Γ c i Inter-domain controller synchronization overhead of controller c i
L c i Load of controller c i
L ¯ The average load of the controller
L B D Load balancing degree of the controller
p s k c o m The communication cost of migrating switch s k
p s k r e q Migration request cost of switch s k
C o s t Total switch migration cost
g The game, containing three elements: players, strategy, and revenue
a L B D Bargaining breakdown point of load balance degree
a C o s t Bargaining breakdown point of migration cost

Share and Cite

MDPI and ACS Style

Li, G.; Li, K.; Liu, Y.; Pan, Y. An Efficient Dynamic Load Balancing Scheme Based on Nash Bargaining in SDN. Future Internet 2019, 11, 252. https://0-doi-org.brum.beds.ac.uk/10.3390/fi11120252

AMA Style

Li G, Li K, Liu Y, Pan Y. An Efficient Dynamic Load Balancing Scheme Based on Nash Bargaining in SDN. Future Internet. 2019; 11(12):252. https://0-doi-org.brum.beds.ac.uk/10.3390/fi11120252

Chicago/Turabian Style

Li, Guoyan, Kaixin Li, Yi Liu, and Yuheng Pan. 2019. "An Efficient Dynamic Load Balancing Scheme Based on Nash Bargaining in SDN" Future Internet 11, no. 12: 252. https://0-doi-org.brum.beds.ac.uk/10.3390/fi11120252

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop