The present embodiments relate generally to a method for determining the number of Virtual Private Networks (VPNs) that can be assigned to a router without exhausting the router memory.
Currently there is no way to determine how many customers should be provisioned on a router by a service provider implementing Virtual Private Network (VPN) services. If too many customers are assigned to a router, the required memory will exceed the router memory, and extra routers must be deployed. The expected commercial benefit is cost reduction. A fully loaded Cisco GSR router costs nearly $1 Million after all the financial loading which includes: office engineering and installation.
Each router with an interface for a VPN must store the entire routing table for that VPN. The largest VPNs consume about 5% of the memory on a Cisco GSR router to which the VPN is assigned. Avoiding having to provision a VPN on two routers can thus save 5% of the memory on the second router which translates to a 5% reduction of the cost of a $1 μmillion router or $50,000. If there are 30 locations and the largest VPN can be provisioned on only one router in the 30 locations, the savings for this VPN alone can be estimated as (30) ($50,000) or $1.5 Million. Saving memory means saving money.
There is a need for a method of determining how many customers can be assigned to a router so that with a high probability the assigned VPNs will not exceed the router's memory.
The embodiments of the invention are a method to determine the maximum number of Virtual Private Networks assignable to plurality of routers in a service provider network implementing Virtual Private Network services. The first step in the method can be to create a tolerance. The tolerance is a probability that consumed router memory will exceed available router memory for each router in a plurality of routers.
The next step in an embodiment can be to compute the consumed router memory on each router in a plurality of routers by summing a route memory, an interface memory, a VPN memory, and a constant memory. The constant amount of memory is independent of the route memory, the interface memory and the VPN memory. The VPN memory can be independent of the number of routes and interfaces for the VPN.
Another step in the method can be computing a number [V] of VPNs assignable to the router to insure that consumed router memory will not exceed the available router memory for each router in a plurality of routers, by solving a nonlinear equation that expresses the consumed router memory as a function of [V]. The nonlinear equation can be solved by using the quadratic formula or by using Newton's method.
The detailed description will be better understood in conjunction with the accompanying drawings as follows:
The present embodiments are detailed below with reference to the listed Figures.
Before explaining the present embodiments in detail, it is to be understood that the embodiments are not limited to the particular embodiments and that they can be practiced or carried out in various ways.
The embodiments of the invention can be for a method of determining how many customers can be assigned to a router that is being used to provide Virtual Private Network (VPN) services. The router can be an edge router, and an edge router is a router to which customers connect.
The method can apply to the problem of assigning interfaces to a Private Edge Router (PER). Since a customer might have multiple VPNs, the problem can be in terms of assigning multiple VPNs to PERs rather than assigning customers to PERs.
The embodiments of the invention allow the assigning of VPNs to a router so that, with a high probability, the router memory will not be exhausted while allowing additional interfaces to be provisioned for the VPNs assigned to the router in a given location without requiring a second router in that location.
The embodiments of the method control costs for a telecommunications service provider. The service provider's costs are minimized by predicting the maximum number of VPNs per router while insuring a low probability of exhausting the router's capabilities. This aspect enables the design of an optimal VPN network based on memory constraints and maximum number of VPNs for a router.
The embodiments of the method enable VPNs to grow on a network without exhausting the memory on a router, and without having to reassign the VPN to another router. Assigning a VPN to a new router causes service disruptions for the VPN. An example of a service disruption occurs if a customer such as a Hospital needs to add additional interfaces to their VPN and the additional interfaces are beyond the capacity of the router to which the Hospital is currently assigned. In this situation, the Hospital will experience a service disruption while its interfaces are reassigned to another router with sufficient interfaces, or the Hospital's VPN will consume memory on a second router to which the additional interfaces are connected. Death or further injury can result from a Hospital not having access to its computer network. The embodiments determine the best use of routers to prevent a customer's VPN from having to be moved to a different router, causing service interruptions, or having to install additional routers.
The embodiments of the method can be used to determine the maximum number of VPNs assignable to a plurality of routers in a VPN network. The router can be a telecommunications network router, such as a model XFL or GSR available from Cisco Systems, Inc. located in San Jose, Calif.
A step in the method can be creating a tolerance. The tolerance is a probability that consumed router memory will exceed available router memory for each router in a plurality of routers. The tolerance can be a parameter [α] which is less than 1 and greater than zero.
A threshold [δ] can also be created such that F(δ)≧1−α, wherein F(δ) is the cumulative probability that a Normal random variable, with mean 0 and variance 1, is less than [δ].
Another step in the method can be computing the consumed router memory on each router in a plurality of routers. The consumed router memory can be computed by summing a route memory, an interface memory, a VPN memory, and a constant memory. The constant amount of memory can be independent of the route memory, the interface memory and the VPN memory. The VPN memory can be independent of the number of routes and interfaces for the VPN.
The route memory can be determined for each router in a plurality of routers in a VPN network by determining a total number of routes over all VPNs that are assigned to a router and multiplying the total number of routes by memory per route. The total number of routes per VPN can be a random variable with a given mean and variance. The mean and variance are determined by analyzing the number of routes for the plurality of VPNs in the VPN network.
The interface memory for each router in a plurality of routers in a VPN network can be determined by computing an average number of interfaces per VPN per router, then multiplying the average number of interfaces per VPN per router by the number of VPNs that are assigned to a router to obtain the total number of interfaces, and multiplying the total number of interfaces by the memory per interface.
The VPN memory for each router in a plurality of routers in a VPN network can be determined by computing an average VPN memory averaged over the plurality of VPNs in the network, then multiplying the average VPN memory by the number of VPNs that are assigned to a router.
The constant memory for each router in a plurality of routers in a VPN network can be determined by computing an average constant memory per router averaged over the plurality of routers in the network.
Another step in the method can be computing a number [V] of VPNs assigned to the router to insure that consumed router memory will not exceed the available router memory for each router in a plurality of routers. The available router memory can be the total memory available in each router in the VPN network.
The number [V] can be computed by the quadratic formula, or by applying Newton's method for solving nonlinear equations, to solve for [V] in an equation that expresses the consumed router memory as a function of [V].
Rather than trying to estimate the distribution of interfaces per VPN per router to compute the number [V], it can be assumed that the number of interfaces per VPN per router is [P]. With this assumption, the total number of interfaces per router can be V·P. The number of interfaces per VPN per router can also be treated as a random variable p(v).
The parameter [Mp] is the memory per interface, [Mv] is the memory per VPN, [Mr] is the memory per route, [A] is available memory, and [M0] is the constant memory per router. We assume that there is a random variable r(v) which is the number of routes per VPN. When there is a set [S] of VPNs on the router and the number of VPNs in the set [S] is [V] then the optimization is accomplished by determining the largest [V] such that:
We assume that:
is approximately distributed as N(Mr·V·μr,Mr2·V·σr2), where N(Mr·V·μr,Mr2·V·σr2) represents a Normal distribution with mean (Mr·V·μr) and variance (Mr2·V·σr2) and where μr is the mean of the random variable r(v) and σr is the standard deviation of the random variable r(v). Using this Normal approximation, the quantity
is (approximately) distributed as a Normal random variable with mean 0 and variance 1.
F(x) can be the cumulative density function of a standardized normal random variable; in other words, F(x) can be the cumulative probability that a normal random variable, with mean 0 and variance 1, is less than x.
Using the Normal approximation,
Let δ satisfy
F(δ)≧1−α
For example, α=0.8414 yields 1−α=0.1586 and δ=1 (one standard deviation), and α=0.02274 yields 1−α=0.97726 and δ=2 (two standard deviations). Hence the required V is obtained by solving
which can be rewritten as the nonlinear equation:
V(Mp·P+Mv+Mr·μr)+δ·Mr·σr·√{square root over (V)}+M0−A=0.
The optimal value of the variable [V] can be obtained by applying the quadratic formula, after substituting x for √{square root over (V)}, resulting in the following equation:
x2(Mp·P+Mv+Mr·μr)+δ·Mr·σr·x+M0−A=0
Defining the constants a, b, and c, wherein,
a=Mp·P+Mv+Mr·μr
b=δ·Mr·σr
c=A−M0
The constants are used to solve the quadratic equation a·x2+b·x−c=0 which results in
and wherein the number [V] of VPNs assignable to the router is V=x2.
Alternatively [V] can be solved by applying Newton's method to solve the equation
V(Mp·P+Mv+Mr·μr)+δ·Mr·σr·√{square root over (V)}+M0−A=0.
When applying Newton's method, the constants can be defined as:
a=Mp·P+Mv+Mr·μr
b=δ·Mr·σr
c=A−M0
The equation to be solved by Newton's method can be written as g(V)=0, where g(V)=aV+b√{square root over (V)}−c=0 and the derivative of g(V) is
Starting with some V0, the iteration of Newton's method can be written as
The initial value for Vi can be V0=c/a.
With reference to the figures,
The router (12) in this figure has available memory (46). Once the consumed memory (38) reaches the amount of available memory (46), no more Virtual Private Networks (48) or interfaces for existing Virtual Private Networks can be added to the router until some of the interfaces or Virtual Private Networks on the router are removed. The consumed memory (38) comprises the constant amount of memory (10), the route memory (24), the interface memory (30) and the VPN memory (32).
V(Mp·P+Mv+Mr·μr)+δ·Mr·σr·√{square root over (V)}+M0−A=0
is solved for each of the four sets of variables using the quadratic formula. As can be seen on the graph, the actual number of Virtual Private Networks that can be used if there are 3 interfaces [P] per VPN is 415 when the probability threshold is 1−F(δ) where δ=1. The value 415 is a much lower number than the initial guess for [V] of 459.78. If δ is increased to 2 as depicted by Set 2 and [P] remains at the value 3, the number of the Virtual Private Networks that can be assigned to the router decreases to 376. The decrease in the probability threshold from 1−F(1) to 1−F(2), increases the probability that the number [V] of Virtual Private Networks assigned to the router will not exhaust the router's resources.
As can be seen on
While these embodiments have been described with emphasis on the embodiments, it should be understood that within the scope of the appended claims, the embodiments might be practiced other than as specifically described herein.
This patent arises from a continuation of U.S. patent application Ser. No. 11/178,178, entitled “Method for Controlling Memory Consumption in Router-Based Virtual Private Networks,” which was filed on Jul. 8, 2005 now U.S. Pat. No. 7,532,632. U.S. patent application Ser. No. 11/178,178 is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6212558 | Antur et al. | Apr 2001 | B1 |
6226751 | Arrow et al. | May 2001 | B1 |
6594704 | Birenback et al. | Jul 2003 | B1 |
6795399 | Benrnohamed et al. | Sep 2004 | B1 |
7039720 | Alfieri et al. | May 2006 | B2 |
20050068961 | Raghunath et al. | Mar 2005 | A1 |
Number | Date | Country | |
---|---|---|---|
20090245139 A1 | Oct 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11178178 | Jul 2005 | US |
Child | 12414521 | US |