CA2462096A1 - Dynamic load balancing for enterprise ip traffic - Google Patents

Dynamic load balancing for enterprise ip traffic Download PDF

Info

Publication number
CA2462096A1
CA2462096A1 CA002462096A CA2462096A CA2462096A1 CA 2462096 A1 CA2462096 A1 CA 2462096A1 CA 002462096 A CA002462096 A CA 002462096A CA 2462096 A CA2462096 A CA 2462096A CA 2462096 A1 CA2462096 A1 CA 2462096A1
Authority
CA
Canada
Prior art keywords
addresses
activity
address
related information
order
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
CA002462096A
Other languages
French (fr)
Inventor
David L. Chavez
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Avaya Technology LLC
Original Assignee
Avaya Technology LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Avaya Technology LLC filed Critical Avaya Technology LLC
Publication of CA2462096A1 publication Critical patent/CA2462096A1/en
Abandoned legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/11Identifying congestion
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/12Avoiding congestion; Recovering from congestion
    • H04L47/125Avoiding congestion; Recovering from congestion by balancing the load, e.g. traffic engineering
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/26Flow control; Congestion control using explicit feedback to the source, e.g. choke packets
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/45Network directories; Name-to-address mapping
    • H04L61/4505Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols
    • H04L61/4511Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols using domain name system [DNS]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1004Server selection for load balancing
    • H04L67/1008Server selection for load balancing based on parameters of servers, e.g. available memory or workload
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1004Server selection for load balancing
    • H04L67/101Server selection for load balancing based on network conditions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1027Persistence of sessions during load balancing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1029Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers using data related to the state of servers by a load balancer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1038Load balancing arrangements to avoid a single path through a load balancer

Abstract

A method for effecting load balancing in a packet-switched network is provided. In one embodiment, the method includes the steps of:
(a) providing a set of Internet Protocol (IP) addresses corresponding to a Universal Resource Locator (URL), wherein the ordering of the IP addresses in the set of IP addresses is indicative of a corresponding desirability of contacting each of the IP
addresses and wherein the set of IP addresses are in a first order;
(b) receiving activity-related information associated with at least one of the IP addresses;
and (c) reordering the set of IP addresses to be in a second order different from the first order.

Description

DYNAMIC LOAD BALANCING FOR ENTERPRISE IP TRAFFIC
FIELD OF THE INVENTION
The present invention relates generally to load balancing and specifically to load balancing in packet-switched networks.
BACKGROUND OF THE INVENTION
The Domain Name System, or DNS, is a naming scheme for dotted decimal Internet Protocol, or IP, addresses. Every computer, or host, on the Internet has an IP
address assigned to it; that is, every host name refers to an IP address. A "domain name" is a logical name or host name assigned to an IP address and used as another type of addressing construct for identifying Internet nodes. Unlike IP addresses, domain names, such as BillSmith@aol.com and www.ultimateelectronics.com, are designed to easily be remembered and used by people. By way of illustration, IP addresses are generally machine readable numeric sequences that are 32 bits in length. A domain name service resolves domain names to IP addresses and vice versa.
The domain name service uses a client/server mechanism, with domain name resolvers as the clients and domain name servers as the servers, and is implemented as a distributed database, existing in a domain name space, whereby each domain generally keeps records only of its next-level subdomains. The domain space is organized hierarchically, with the root domain at the top and the rest of the structure branching from the root domain. All domain name resolvers have a pointer to the root domain (served by multiple servers), which in turn have pointers to all the top-level domains (those one level below the root domain), which in turn have pointers to their subdomains, so that any name within the name space can be queried and resolved efficiently.
In partitioned, packet-switched, distributed processing networks using DNS
technology, traffic shaping or load balancing has continued to present challenges to network designers. For example, IP telephony traffic is directed by domain name servers to proxies that further direct the traffic to authoritative domains for the call request. Domain name servers, however, do not shape the call based on traffic. Core proxies that distribute calls to authoritative proxies do not shape traffic either. The current use of IP telephony is predominantly to make calls to individuals (e.g., sip:davidchavez@sip.avaya.com). As IP telephony becomes increasingly popular, users will use IP telephony to place calls to general business or enterprise addresses associated with contact centers (e.g., customer service@sip.avaya.com) having multiple call servicing agents. For efficient service goals and objectives to be realized, IP telephony calls to contact centers will need to be distributed to agents and proxies to reflect current or anticipated traffic or loads. In other examples, similar problems exist when specific web addresses are too popular at certain intervals. In particular, server farms, for optimal operation, require some type of load balancing to substantially minimize the time required to respond to content requests.
Compared to packet-switched networks, a number of effective load balancing algorithms have been developed for circuit-switched networks. In circuit-switched telephony, incoming trunks are generally spread through the enterprise network of Private Branch Exchanges or PBXs. Within the enterprise, traffic can be shaped through PBX hierarchy or network services for call redirection/deflection. For example in Best Services RoutingTM of Avaya, Inc., PBXs communicate with one another regarding their current estimated wait times for call servicing.
When a call arnves, the estimated wait times are used to redirect the incoming call to an appropriate PBX. In Network RouteTM of Avaya, Inc., an adjunct processor is used to acquire estimated wait times for a plurality of PBXs. Rather than have a call come into a first PBX and then have to redirect the call to a second PBX the adjunct processor uses SS7 technology to shape the Public Switched Telephone Network or PSTN routing so that the call is optimally directed at the outset to the PBX that is best able to handle it.
The load balancing/traffic shaping algorithms used for circuit-switched applications, however, are generally unsuitable for packet-switched applications due to the differing mechanisms used to direct or route incoming contacts. In circuit-switched applications, an OSI
Layer 4 network is available to permit redirection of contacts optimally. In packet-switched applications, once a destination IP address is selected there are substantial costs involved with redirect the contact to a different IP address.
2 SUMMARY OF THE INVENTION
These and other needs are addressed by the various embodiments and configurations of the present invention. The present invention is directed generally to a methodology and system for load balancing or traffic shaping in a partitioned, packet-switched network.
In one embodiment, a method for performing name resolution in the packet-switched network is provided that includes the steps of:
(a) providing a set of first addresses (e.g., Internet Protocol addresses) corresponding to a second address (e.g., host name), the ordering of the first addresses in the set of first addresses being indicative of a relative desirability of contacting each of the first addresses;
(b) receiving activity-related information associated with one or more of the first addresses;
(c) based on the received activity-related information, reordering the set of first addresses to be in a different order;
(d) receiving a resolution query for the second address; and (e) providing one or more of the reordered first addresses in response to the query.
In an exemplary application, each of the set of first addresses is an IP
address, the second address is a domain name, and the set of addresses are in an enterprise network. The steps are preferably performed by a domain name server in response to a domain name or URL resolution query requesting mapping of the domain name to an IP address.
The activity-related information is typically provided by one or more nodes in the domain or subdomain for which the domain name server is authoritative. The nodes may be any computational component, such as a telephony switch, a media server, a proxy server, communications adjunct, media gateway controller, and softswitch.
The activity-related information is broadly related to the contact/contactor and/or the destination for the contact. For example, the information can be a performance metric of a telephony switch or media server. Other examples of activity-related information include at least the following: an estimated wait time to service a contact, an actual wait time to service existing enqueued contacts, an available processor capacity, a processor capacity currently in use, a length of a work item queue, an available bandwidth, an unavailable bandwidth, an agent staffing level,
3 an available agent skill level, a purpose of a contact, a skill level required to service a contact, and a number of active sessions.
Based on the activity-related information a suitable algorithm is used to reorder dynamically the first addresses such that the most desirable address for the incoming contact is provided to the contacting device. By way of example, when the activity-related information is wait time the most desirable address typically has the lowest wait time among the first addresses.
When the activity-related information is available bandwidth, the most desirable address typically has the highest available bandwidth among the first addresses. When the activity related information is available processor capacity, the most desirable address typically has the highest available processor capacity.
As noted, the activity-related information can be associated with the contact and/or contactor. For example, the activity-related information can be a qualifier in a domain name or a cookie. As will be appreciated, a qualifier refers to logical subcomponent of a domain name and a cookie to information stored on a user's computer by a Web browser at the request of a Web site visited by the browser. Typically, cookies are used by Web sites to recognize users who have previously visited the site. The next time the user accesses the site, the information in the cookie is sent back to the site so the Web site can know the user's preferences in serving the user.
The methodology and system of the present invention can have a number of advantages.
For example, the above methodology can allow IP traffic to be shaped in an IP
trunked network in a way not currently possible with SIP/DNS-based technology. By dynamically updating the IP address lists for a corresponding domain name, incoming contacts are forwarded directly to the desirable destination rather than being redirected one or more times by other nodes in the IP
address list to the desirable destination. The ability to directly forward contacts to the desired location can not only lead to less network traffic and increased computational efficiency but can also provide increased levels of customer/contactor satisfaction. This can be a potentially important technology for providers that experience heavy bursty type traffic but have geographically dispersed servers that could better handle the offered traffic if the selection of
4 service was better shaped. The ability of the methodology to use qualifiers and cookies can provide guidance as to where to direct the incoming contact to better service the contactor.
These and other advantages will be apparent from the disclosure of the inventions) contained herein.
The above-described embodiments and configurations are neither complete nor exhaustive. As will be appreciated, other embodiments of the invention are possible utilizing, alone or in combination, one or more of the features set forth above or described in detail below.
BRIEF DESCRIPTION OF THE DRAWINGS
Fig. 1 is a block diagram of an illustrative embodiment of the present invention;
Fig. 2 depicts a list of IP addresses output by the domain server in response to a request for name resolution;
Fig. 3 depicts a first operational embodiment of the activity assessment agent;
Fig. 4 depicts a second operational embodiment of the activity assessment agent; and Fig. 5 depicts an operational embodiment of the reporting agent.
DETAILED DESCRIPTION
The Architecture Fig. 1 illustrates an exemplary embodiment of the present invention.
A packet-switched communication device 100 and a proxy server 104 are in communication with a partitioned data or distributed processing network 108.
The communication device 100 can be any communication device suitable for the packet-switched network. The communication device 100 can include, for example, IP hardphones, IP
softphones, Personal Digital Assistants or PDAs, Personal Computers or PCs, and laptops. The proxy server 104 can be any suitable proxy server, such as a core or authoritative proxy server, whether configured for the Session Initiation Protocol or SIP or any telecommunications protocol such as H.323 and the like. The packet-switched network 108 can be any partitioned data and/or distributed processing network, such as an intranetwork or an internetwork (e.g., the Internet).
5 The network 108 typically includes additional proxy servers (not shown), registrars (not shown), gateways (not shown), and routers (not shown) for managing packet flows.
The dashed box 112 represents a domain or subdomain within the network 108. As will be appreciated, a domain will typically include one or more subdomains (not shown), each of which is serviced by one or more (sub)domain name servers that are authoritative for the subdomain. The domain/subdomain 112 includes a plurality of domain name servers 116a-n that are authoritative for the domain/subdomain and a plurality of switches and/or servers 120a-n located having host/IP addresses within the domain/subdomain. As will be appreciated, other host computational components, such as communication devices, media servers, media gateways, communication adjuncts, and the like, can be located within the domain/subdomain but are not illustrated for purposes of simplicity. As will be appreciated, a "host"
refers to any computational component on the network, whether or not its primary purpose is to provide resources via the network. As will be appreciated, the domain name servers 116a-n generally maintain records only of each of their next-level subdomains.
1 S The domain name servers 116 a-n act as both resolvers and domain name servers. In other words, they answer name resolution queries for which they are authoritative and attempt to resolve or query other name servers about information regarding domains for which they are not authoritative. The servers 116 a-n are able to handle both recursive and iterative name resolution queries. As will be appreciated in recursive queries, the name server follows successive referrals until the requested information is found and, in iterative queries, the queried name server must return the requested information or the name of a name server that can in turn be queried for the requested information. To reduce network traffic and answer queries more quickly, the name servers preferably store in a cache the information that they receive in response to name resolution queries.
The switch/servers 120a-n direct communications, such as incoming Voice Over IP or VoIP calls, in an associated enterprise network serviced by the switchlserver.
The switch/(media) servers can be any architecture for directing contacts to one or more communication devices. Illustratively, the switch/servers 120 of Fig. 1 can be the subscriber-premises equipment disclosed in U.S. Patents 6,192,122; 6,173,053; 6,163,607;
5,982,873;
6 5,905,793; 5,828,747; and 5,206,903, all of which are incorporated herein by this reference;
Avaya Inc.'s DEFINITYTM or MULTI-~ANTAGETM private-branch exchange (PBX)-based ACD system. The switch or media servers 120 typically are a stored-program-controlled systems that conventionally include interfaces to external communication links, a communications switching fabric, service circuits (e.g., tone generators, announcement circuits, etc. ), memory for storing control programs and data, and a processor (i.e., a computer) for executing the stored control programs to control the interfaces and the fabric and to provide automatic contact-distribution functionality. The switch/servers each comprise a network interface card to provide services to the associated plurality of communication devices. The switchlservers can be decomposed into a feature server or call control server and a gateway (not shown) to provide signal control and conversion capabilities between the circuit-switched PSTN
or some other type of circuit-switched network (not shown) and the packet-switched network 108.
The domain name server 116a-n includes or is in communication with an associated activity assessment agent 124a-n, which receives activity-related (or state) information from a 1 S reporting agent 128a-n in each of the switch/servers. The activity-related information generally describes or indicates the ability or inability of the host associated with the reporting agent to service or otherwise handle a work item, such as an incoming contact, a request for information, processor load available bandwidth, and the like, and/or to a state of the host. For example, the activity-related information can be a metric indicative of the workload of the associated switch/server, such as estimated wait time to service a contact, actual wait time to service existing enqueued contacts, available processor (CPU) capacity, processor (CPU) capacity currently in use, lengths of work item queues (or contact center occupancy), available bandwidth, unavailable bandwidth, agent staffing levels, available agent skill levels, purpose of contact, skill level required to service a contact, number of active sessions, and the like.
The activity assessment agent 124 in each of the domain name servers performs traffic shaping or load balancing based on the activity-related information. This is effected by reordering a collection of addresses (typically IP addresses) such that the possible destinations of the contact are ranked in ascending or descending order of preference or according to any other suitable ordering technique. For example, Fig. 2 depicts a list of IP
addresses associated
7 with a corresponding host address or domain name. The list of destination IP
addresses presents or orders the IP addresses in order of preference, with the more preferred destination address being at the top of the list and the least preferred at the bottom. The list of destination IP
addresses is presented by a domain name server (acting as a server) to a domain name server (acting as a resolver) in response to a name resolution query for the associated domain name.
The activity assessment agent 124 updates the ordering of the addresses in the list in response to the receipt of activity-related information from the reporting agent(s).
Any suitable algorithm may be used by the activity assessment agent to process the activity-related information and determine the desirable ordering of IP
addresses. The algorithm may be as sophisticated or simple as desired. For example, in an IP telephony and contact center context the activity assessment agent can base the ordering of IP addresses on the relative estimated wait times of the switches/servers. Thus, the switch/server having the lowest estimated wait time is listed as the most preferred destination address and the switch/server having the highest estimated wait time as the least preferred destination address. A similar 1 S approach can be used for any other quantitative metric, such as available bandwidth, available processor capacity, lengths of work item queues, and the like, whereby the address having the least workload is the most preferred address and that having the most workload is the least preferred address. In another example, the agent bases the ordering of the addresses on the switch/server having the available skills) required to service the contact or the information of interest to the contactor. For example if the Universal Resource Locator or URL or host address has a qualifier (which denotes the nature or purpose of the contact), the qualifier can be used to route the contact. Thus, in the host address "www.ultimateelectronics.com/HDTV" the qualifier "HDTV" indicates that the contactor is interested in high density televisions.
The contactor would then be directed to an agent skilled in high density televisions.
Cookies may also be used to effect type of routing. Examples of other algorithms can be found in the PBX-based Customer Resource Management field. In this configuration, the activity-related information is embedded in or attached to the URL itself and is not received from a reporting agent.
The assessment agent would update the IP address list ordering before selecting an IP address to return to the resolver.

The Operation of the Reporting-Agent The operation of the reporting agent 128 will now be discussed with reference to Fig. 5.
In step 500, the agent 128 is in a wait state. When a predetermined event is detected in step 504, the agent 128 in step 508 collects selected or predetermined types of activity related information. The predetermined event can be the expiration of a selected time interval, the magnitude of one or more selected metrics such as estimated wait time, work item volume, and staffing level. The predetermined event can be detected by the agent itself or another computational component in the switch/server. In step 512, the agent 128 transmits the collected activity-related information to one or more selected activity assessment agents in the associated domain or subdomain. In a preferred configuration, the information is provided to the activity assessment agent in each of the domain name servers in the associated domain or subdomain.
The agent then returns to the wait state in step 500.
In another embodiment, the agent periodically updates internal records to reflect collected activity-related information and less frequently sends the updated information to the activity assessment agent.
Operation of the Activity Assessment Agent Referring to Fig. 3, an operational embodiment of the activity assessment agent 124 will now be discussed.
In step 300, the agent 124 is in a wait state until an update request containing activity-related information or URL resolution request or name resolution query is received. A query is typically received for every incoming call to a URL.
In step 304, the agent 124 receives the update message from the reporting agent 128 containing the activity-related information. In step 308, the agent 124 retrieves the IP address list for the various switches/servers identified by the domain name and/or in the corresponding enterprise network from the domain name/IP address records in the associated domain server database (not shown), applies the desired algorithm to process the activity-related information, updates the ordering of IP addresses in the list based on the received activity-related information, and saves the updated IP address in the database.
The agent 124 then returns to the wait state in step 300.
Fig. 4 depicts a second operational embodiment of the activity assessment agent 124 when a URL resolution request is received in step 300 from a domain name server acting as a resolver or from a proxy server. In SIP, proxy servers first send a URL
resolution query to a domain name server to obtain the most desired destination IP address for the URL identified in a corresponding INVITE message. This, of course, is done before forwarding the INVITE
message to the URL referenced in the message.
In step 400, the agent 124 retrieves from the associated database the list of IP addresses associated with the URL in the URL resolution request. In step 404, the agent 124 effects the transmission of a response to the resolver with the most desirable IP address in the currently updated list of IP addresses associated with the URL alone or together with the currently updated list itself.
1 S The agent then returns to the wait state in step 300.
After receiving the most desired address, the contactor will attempt a contact directly to the returned IP address.
In IP telephony, a proxy server is normally the name resolution requestor.
After the response to the URL resolution request is received, the requesting proxy server changes the destination address in the INVITE message (which prompted the URL resolution request) to the most preferred destination address and forwards the message to the destination. In IP telephony applications, the returned IP address will typically be the IP address of a proxy server serving the destination endpoint. The identified proxy server will take the incoming contact and direct signaling of the contact to the destination endpoint (agent or service). The endpoint serviced by the proxy server, upon receipt of the "INVITE" message, will send an "OK"
message to the initiator's device. The "OK" message includes, among other things, an IP
address to use for terminating the RTP stream and the IP address to use for sending the RTP
stream to the initiator.
A number of variations and modifications of the invention can be used. It would be possible to provide for some features of the invention without providing others.

For example in one alternative embodiment, the methodology of the present invention is not limited to IP telephony but can be used with a group of replicated servers or a server farm in a Web site. In this embodiment, the activity assessment agent 124, based on activity-related information received from each content server in the server farm, reorders the IP address list such that incoming content requests are directed to the particular content server that is best able to service the request; that is, the request is directed to the content server that has the highest available CPU and/or currently contains the content that is sought by the request. The contactor's Web server then contacts the most preferred IP address in the IP
address list.
In yet another alternative embodiment, the switches/servers 120 include one or more proxy servers, or are replaced by other knowledgeable elements, such as softswitches, media gateway controllers, and communication adjuncts. The proxy servers/other knowledgeable elements would each include a reporting agent 128 and are located with the domain/subdomain for which the associated domain name server is authoritative. The proxy servers/other knowledgeable elements update internal records based on metrics such as overall traffic/performance and upon the occurrence of the predetermined event send the information to the assessment agent in the domain name server.
In yet another alternative embodiment, a core proxy server would replace the domain name server with equivalent functionality. In other words, the above methodology is used in contact list resolution under SIP. This operation is typically performed on the user agent of the destination. As will be appreciated, a core proxy server is authoritative for an enterprise network. The domain name server could perform part of the name resolution and the core proxy the other part. In that event, the domain name server effects name resolution on the domain part of the URL (namely everything after the "@" symbol) while the core proxy server effects name resolution on the remainder of the URL.
In yet another alternative embodiment, the activity assessment and reporting agents are implemented as a logic circuit or as a combination of a logic circuit and software.
The present invention, in various embodiments, includes components, methods, processes, systems and/or apparatus substantially as depicted and described herein, including various embodiments, subcombinations, and subsets thereof. Those of skill in the art will understand how to make and use the present invention after understanding the present disclosure.
The present invention, in various embodiments, includes providing devices and processes in the absence of items not depicted and/or described herein or in various embodiments hereof, including in the absence of such items as may have been used in previous devices or processes, e.g., for improving performance, achieving ease and\or reducing cost of implementation.
The foregoing discussion of the invention has been presented for purposes of illustration and description. The foregoing is not intended to limit the invention to the form or forms disclosed herein. In the foregoing Detailed Description for example, various features of the invention are grouped together in one or more embodiments for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed invention requires more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive aspects lie in less than all features of a single foregoing disclosed embodiment. Thus, the following claims are hereby incorporated into this Detailed Description, with each claim standing on its own as a separate preferred embodiment of the invention.
Moreover though the description of the invention has included description of one or more embodiments and certain variations and modifications, other variations and modifications are within the scope of the invention, e.g., as may be within the skill and knowledge of those in the art, after understanding the present disclosure. It is intended to obtain rights which include alternative embodiments to the extent permitted, including alternate, interchangeable and/or equivalent structures, functions, ranges or steps to those claimed, whether or not such alternate, interchangeable and/or equivalent structures, functions, ranges or steps are disclosed herein, and without intending to publicly dedicate any patentable subject matter.

Claims (38)

What is claimed is:
1. A method for performing name resolution in a packet-switched network, comprising:
providing a set of first addresses corresponding to a second address, wherein the ordering of at least some of the first addresses in the set of first addresses is indicative of a relative desirability of contacting each of the at least some of first addresses and wherein the set of first addresses are in a first order;
receiving activity-related information associated with at least one of the first addresses;
based on the received activity-related information, reordering the set of first addresses to be in a second order different from the first order;
receiving a resolution query for the second address; and providing at least one of the reordered first addresses in response to the query.
2. The method of Claim 1, wherein each of the set of first addresses is an IP
address, wherein the second address is a host name, and wherein the set of addresses are in an enterprise network.
3. The method of Claim 2, wherein the host name is a domain name.
4. The method of Claim 1, wherein the activity-related information comprises a performance metric and the set of first address and the second address correspond to nodes of a partitioned network.
5. The method of Claim 1, wherein the activity-related information comprises at least one of the following: an estimated wait time to service a contact, an actual wait time to service existing enqueued contacts, an available processor capacity, a processor capacity currently in use, a length of a work item queue, an available bandwidth, an unavailable bandwidth, an agent staffing level, an available agent skill level, a purpose of a contact, a skill level required to service a contact, a number of active sessions, and cost to service.
6. The method of Claim 1, wherein in the first order a most desirable address is different from a most desirable address in the second order and wherein in the providing step the most desirable address in the second order is included in the at least one of the first addresses.
7. The method of Claim 6, wherein the activity-related information is wait time and the most desirable address in the second order has the lowest wait time among the first addresses.
8. The method of Claim 6, wherein the activity-related information is available bandwidth and the most desirable address in the second order has the highest available bandwidth among the first addresses.
9. The method of Claim 6, wherein the activity-related information is available processor capacity and the most desirable address in the second order has the highest available processor capacity.
10. The method of Claim 1, wherein the activity-related information is a qualifier and wherein the reordering step comprises the step of:
selecting a most desired address among the set of first addresses based on the qualifier.
11. The method of Claim 1, wherein the activity-related information is a cookie and wherein the reordering step comprises the step of:
selecting a most desired address among the set of first addresses based on the contents of the cookie.
12. A computer readable medium comprising instructions operable to perform the steps of Claim 1.
13. A logic circuit operable to perform the steps of Claim 1.
14. A method for effecting load balancing in a packet-switched network, comprising:
providing a set of Internet Protocol (IP) addresses corresponding to a Universal Resource Locator (URL), wherein the ordering of the IP addresses in the set of IP
addresses is indicative of a corresponding desirability of contacting each of the IP addresses and wherein the set of IP
addresses are in a first order;
receiving activity-related information associated with at least one of the IP
addresses; and based at least in part on the received activity-related information, reordering the set of IP addresses to be in a second order different from the first order.
15. The method of Claim 14, further comprising:
receiving a resolution query for the URL; and providing a most desirable of the IP addresses in response to the query.
16. The method of Claim 14, wherein the activity-related information comprises a performance metric.
17. The method of Claim 14, wherein the activity-related information comprises at least one of the following: an estimated wait time to service a contact, an actual wait time to service existing enqueued contacts, an available processor capacity, a processor capacity currently in use, a length of a work item queue, an available bandwidth, an unavailable bandwidth, an agent staffing level, an available agent skill level, a purpose of a contact, a skill level required to service a contact, a number of active sessions, and cost to service.
18. The method of Claim 14, wherein in the first order a most desirable address is different from a most desirable address in the second order.
19. The method of Claim 18, wherein the activity-related information is wait time and the most desirable address in the second order has the lowest wait time among the IP addresses.
20. The method of Claim 18, wherein the activity-related information is available bandwidth and the most desirable address in the second order has the highest available bandwidth among the IP addresses.
21. The method of Claim 18, wherein the activity-related information is available processor capacity and the most desirable address in the second order has the highest available processor capacity.
22. The method of Claim 14, wherein the activity-related information is a qualifier and wherein the reordering step comprises the step of:
selecting a most desired address among the set of IP addresses based on the qualifier.
23. The method of Claim 14, wherein the activity-related information is a cookie and wherein the reordering step comprises the step of:
selecting a most desired address among the set of IP addresses based on the contents of the cookie.
24. A computer readable medium comprising instructions operable to perform the steps of Claim 14.
25. A logic circuit operable to perform the steps of Claim 14.
26. A system for effecting traffic shaping in a packet-switched network, comprising:
(a) an enterprise network comprising a plurality of nodes corresponding to a set of first addresses, wherein the set of first addresses are associated with a second address, wherein the ordering of the first addresses in the set of first addresses is indicative of a relative desirability of contacting each of the first addresses, and wherein the set of first addresses are in a first order;
and (b) an activity assessment agent operable to:
(i) receive activity-related information associated with at least one of the first addresses;
(ii) based at least in part on the received activity-related information, reorder the set of first addresses to be in a second order different from the first order;
(iii) receive a resolution query for the second address; and (iv) provide at one of the reordered first addresses in response to the query.
27. The system of Claim 26, wherein each of the set of first addresses is an IP address and wherein the second address is a host name.
28. The system of Claim 27, wherein the host name is a domain name.
29. The system of Claim 26, wherein the activity-related information comprises a performance metric and the set of first address and the second address correspond to nodes of a partitioned network.
30. The system of Claim 26, wherein the activity-related information comprises at least one of the following: an estimated wait time to service a contact, an actual wait time to service existing enqueued contacts, an available processor capacity, a processor capacity currently in use, a length of a work item queue, an available bandwidth, an unavailable bandwidth, an agent staffing level, an available agent skill level, a purpose of a contact, a skill level required to service a contact, a number of active sessions, and cost to service.
31. The system of Claim 26, wherein in the first order a most desirable address is different from a most desirable address in the second order and wherein in the provide operation (iv) the most desirable address is included in the at least one of the first addresses.
32. The system of Claim 31, wherein the activity-related information is wait time and the most desirable address in the second order has the lowest wait time among the first addresses.
33. The system of Claim 31, wherein the activity-related information is available bandwidth and the most desirable address in the second order has the highest available bandwidth among the first addresses.
34. The system of Claim 31, wherein the activity-related information is available processor capacity and the most desirable address in the second order has the highest available processor capacity.
35. The system of Claim 26, wherein the activity-related information is a qualifier and wherein the reordering operation comprises the function of:
selecting a most desired address among the set of first addresses based on the qualifier.
36. The system of Claim 26, wherein the activity-related information is a cookie and wherein the reordering operation comprises the function of:
selecting a most desired address among the set of first addresses based on the contents of the cookie.
37. The system of Claim 26, further comprising:
(c) a reporting agent located in a host device in the enterprise network, the reporting agent being operable to collect and provide the activity-related information to the activity assessment agent.
38. The system of Claim 37, wherein the activity assessment agent is part of a domain name server authoritative for a domain including the enterprise network and further comprising a plurality of reporting agents corresponding to a plurality of host devices in communication with the activity assessment agent and having addresses within the domain, wherein at least some of the reporting agents have addresses outside of the enterprise network.
CA002462096A 2003-04-30 2004-03-26 Dynamic load balancing for enterprise ip traffic Abandoned CA2462096A1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US10/427,813 US7308499B2 (en) 2003-04-30 2003-04-30 Dynamic load balancing for enterprise IP traffic
US10/427,813 2003-04-30

Publications (1)

Publication Number Publication Date
CA2462096A1 true CA2462096A1 (en) 2004-10-30

Family

ID=32990457

Family Applications (1)

Application Number Title Priority Date Filing Date
CA002462096A Abandoned CA2462096A1 (en) 2003-04-30 2004-03-26 Dynamic load balancing for enterprise ip traffic

Country Status (5)

Country Link
US (1) US7308499B2 (en)
EP (1) EP1473907B1 (en)
CN (1) CN1571388B (en)
CA (1) CA2462096A1 (en)
DE (1) DE602004008693T2 (en)

Families Citing this family (140)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7020707B2 (en) * 2001-05-30 2006-03-28 Tekelec Scalable, reliable session initiation protocol (SIP) signaling routing node
FR2851867B1 (en) * 2003-02-28 2005-06-24 Cit Alcatel ORDERING ADDRESSES IN DOMAIN NAME SERVER
US8094804B2 (en) 2003-09-26 2012-01-10 Avaya Inc. Method and apparatus for assessing the status of work waiting for service
DE10357118A1 (en) * 2003-12-06 2005-07-07 Daimlerchrysler Ag Loading software modules
US7822016B2 (en) * 2004-01-20 2010-10-26 Aspect Software, Inc. IP ACD using SIP format
US20060039352A1 (en) * 2004-08-19 2006-02-23 International Business Machines Corporation System and method for designating a priority access order of domain name service servers
JP3859667B2 (en) * 2004-10-26 2006-12-20 株式会社日立製作所 Data communication method and system
US7675854B2 (en) 2006-02-21 2010-03-09 A10 Networks, Inc. System and method for an adaptive TCP SYN cookie with time validation
JP4561671B2 (en) * 2006-03-30 2010-10-13 株式会社日立製作所 Data communication method and system
US7929419B2 (en) * 2006-08-04 2011-04-19 Tekelec Methods, systems, and computer program products for inhibiting message traffic to an unavailable terminating SIP server
EP2050251B1 (en) * 2006-08-10 2018-10-10 Thomson Licensing Method for the diffusion of information in a distributed network
CN100456702C (en) * 2006-09-27 2009-01-28 北京航空航天大学 Equation method for network resource load
US8312507B2 (en) 2006-10-17 2012-11-13 A10 Networks, Inc. System and method to apply network traffic policy to an application session
US8584199B1 (en) 2006-10-17 2013-11-12 A10 Networks, Inc. System and method to apply a packet routing policy to an application session
US8028090B2 (en) 2008-11-17 2011-09-27 Amazon Technologies, Inc. Request routing utilizing client location information
US7991910B2 (en) 2008-11-17 2011-08-02 Amazon Technologies, Inc. Updating routing information based on client location
WO2009018418A2 (en) 2007-07-31 2009-02-05 Tekelec Systems, methods, and computer program products for distributing application or higher layer communications network signaling entity operational status information among session initiation protocol (sip) entities
US7962597B2 (en) 2008-03-31 2011-06-14 Amazon Technologies, Inc. Request routing based on class
US8156243B2 (en) 2008-03-31 2012-04-10 Amazon Technologies, Inc. Request routing
US8321568B2 (en) 2008-03-31 2012-11-27 Amazon Technologies, Inc. Content management
US8606996B2 (en) 2008-03-31 2013-12-10 Amazon Technologies, Inc. Cache optimization
US8447831B1 (en) 2008-03-31 2013-05-21 Amazon Technologies, Inc. Incentive driven content delivery
US8601090B1 (en) 2008-03-31 2013-12-03 Amazon Technologies, Inc. Network resource identification
US7970820B1 (en) 2008-03-31 2011-06-28 Amazon Technologies, Inc. Locality based content distribution
US8533293B1 (en) 2008-03-31 2013-09-10 Amazon Technologies, Inc. Client side cache management
US9912740B2 (en) 2008-06-30 2018-03-06 Amazon Technologies, Inc. Latency measurement in resource requests
US7925782B2 (en) 2008-06-30 2011-04-12 Amazon Technologies, Inc. Request routing using network computing components
US9407681B1 (en) 2010-09-28 2016-08-02 Amazon Technologies, Inc. Latency measurement in resource requests
US8948367B2 (en) * 2008-08-19 2015-02-03 Avaya Inc. Rerouting of trunks by a PBX to an alternate PBX
US8073940B1 (en) 2008-11-17 2011-12-06 Amazon Technologies, Inc. Managing content delivery network service providers
US8732309B1 (en) 2008-11-17 2014-05-20 Amazon Technologies, Inc. Request routing utilizing cost information
US8122098B1 (en) 2008-11-17 2012-02-21 Amazon Technologies, Inc. Managing content delivery network service providers by a content broker
US8065417B1 (en) 2008-11-17 2011-11-22 Amazon Technologies, Inc. Service provider registration by a content broker
US8521880B1 (en) 2008-11-17 2013-08-27 Amazon Technologies, Inc. Managing content delivery network service providers
US8060616B1 (en) 2008-11-17 2011-11-15 Amazon Technologies, Inc. Managing CDN registration by a storage provider
WO2010099514A2 (en) * 2009-02-27 2010-09-02 Coach Wei System and method for computer cloud management
US20100223364A1 (en) * 2009-02-27 2010-09-02 Yottaa Inc System and method for network traffic management and load balancing
WO2010102084A2 (en) * 2009-03-05 2010-09-10 Coach Wei System and method for performance acceleration, data protection, disaster recovery and on-demand scaling of computer applications
US8521851B1 (en) 2009-03-27 2013-08-27 Amazon Technologies, Inc. DNS query processing using resource identifiers specifying an application broker
US8412823B1 (en) 2009-03-27 2013-04-02 Amazon Technologies, Inc. Managing tracking information entries in resource cache components
US8756341B1 (en) * 2009-03-27 2014-06-17 Amazon Technologies, Inc. Request routing utilizing popularity information
US8688837B1 (en) 2009-03-27 2014-04-01 Amazon Technologies, Inc. Dynamically translating resource identifiers for request routing using popularity information
CN102859934B (en) * 2009-03-31 2016-05-11 考持·维 Access-in management and safety system and the method for the accessible Computer Service of network
US8782236B1 (en) 2009-06-16 2014-07-15 Amazon Technologies, Inc. Managing resources using resource expiration data
US8397073B1 (en) 2009-09-04 2013-03-12 Amazon Technologies, Inc. Managing secure content in a content delivery network
US8433771B1 (en) 2009-10-02 2013-04-30 Amazon Technologies, Inc. Distribution network with forward resource propagation
US9960967B2 (en) 2009-10-21 2018-05-01 A10 Networks, Inc. Determining an application delivery server based on geo-location information
US9495338B1 (en) 2010-01-28 2016-11-15 Amazon Technologies, Inc. Content distribution network
US8644324B2 (en) * 2010-02-12 2014-02-04 Tekelec, Inc. Methods, systems, and computer readable media for providing priority routing at a diameter node
US8243960B2 (en) * 2010-03-04 2012-08-14 Bose Corporation Planar audio amplifier output inductor with current sense
US8605132B1 (en) * 2010-03-26 2013-12-10 Insors Integrated Communications Methods, systems and program products for managing resource distribution among a plurality of server applications
US9071512B2 (en) 2010-08-06 2015-06-30 Tekelec, Inc. Methods, systems, and computer readable media for distributing diameter network management information
US8443078B2 (en) * 2010-08-20 2013-05-14 International Business Machines Corporation Method of determining equivalent subsets of agents to gather information for a fabric
US10958501B1 (en) 2010-09-28 2021-03-23 Amazon Technologies, Inc. Request routing information based on client IP groupings
US10097398B1 (en) 2010-09-28 2018-10-09 Amazon Technologies, Inc. Point of presence management in request routing
US8819283B2 (en) 2010-09-28 2014-08-26 Amazon Technologies, Inc. Request routing in a networked environment
US8577992B1 (en) 2010-09-28 2013-11-05 Amazon Technologies, Inc. Request routing management based on network components
US8924528B1 (en) 2010-09-28 2014-12-30 Amazon Technologies, Inc. Latency measurement in resource requests
US8938526B1 (en) 2010-09-28 2015-01-20 Amazon Technologies, Inc. Request routing management based on network components
US8468247B1 (en) 2010-09-28 2013-06-18 Amazon Technologies, Inc. Point of presence management in request routing
US9712484B1 (en) 2010-09-28 2017-07-18 Amazon Technologies, Inc. Managing request routing information utilizing client identifiers
US9003035B1 (en) 2010-09-28 2015-04-07 Amazon Technologies, Inc. Point of presence management in request routing
US8930513B1 (en) 2010-09-28 2015-01-06 Amazon Technologies, Inc. Latency measurement in resource requests
US9215275B2 (en) 2010-09-30 2015-12-15 A10 Networks, Inc. System and method to balance servers based on server load status
US8452874B2 (en) 2010-11-22 2013-05-28 Amazon Technologies, Inc. Request routing processing
US9609052B2 (en) 2010-12-02 2017-03-28 A10 Networks, Inc. Distributing application traffic to servers based on dynamic service response time
US9391949B1 (en) 2010-12-03 2016-07-12 Amazon Technologies, Inc. Request routing processing
US9152293B2 (en) * 2010-12-09 2015-10-06 Verizon Patent And Licensing Inc. Server IP addressing in a computing-on-demand system
US10467042B1 (en) 2011-04-27 2019-11-05 Amazon Technologies, Inc. Optimized deployment based upon customer locality
US8897154B2 (en) 2011-10-24 2014-11-25 A10 Networks, Inc. Combining stateless and stateful server load balancing
US9386088B2 (en) 2011-11-29 2016-07-05 A10 Networks, Inc. Accelerating service processing using fast path TCP
US9094364B2 (en) 2011-12-23 2015-07-28 A10 Networks, Inc. Methods to manage services over a service gateway
US10044582B2 (en) 2012-01-28 2018-08-07 A10 Networks, Inc. Generating secure name records
US8904009B1 (en) 2012-02-10 2014-12-02 Amazon Technologies, Inc. Dynamic content delivery
US10021179B1 (en) 2012-02-21 2018-07-10 Amazon Technologies, Inc. Local resource delivery network
US9172674B1 (en) 2012-03-21 2015-10-27 Amazon Technologies, Inc. Managing request routing information utilizing performance information
US10623408B1 (en) 2012-04-02 2020-04-14 Amazon Technologies, Inc. Context sensitive object management
US9154551B1 (en) 2012-06-11 2015-10-06 Amazon Technologies, Inc. Processing DNS queries to identify pre-processing information
US8782221B2 (en) 2012-07-05 2014-07-15 A10 Networks, Inc. Method to allocate buffer for TCP proxy session based on dynamic network conditions
US9525659B1 (en) 2012-09-04 2016-12-20 Amazon Technologies, Inc. Request routing utilizing point of presence load information
US9135048B2 (en) 2012-09-20 2015-09-15 Amazon Technologies, Inc. Automated profiling of resource usage
US9323577B2 (en) 2012-09-20 2016-04-26 Amazon Technologies, Inc. Automated profiling of resource usage
US10021174B2 (en) 2012-09-25 2018-07-10 A10 Networks, Inc. Distributing service sessions
US9843484B2 (en) 2012-09-25 2017-12-12 A10 Networks, Inc. Graceful scaling in software driven networks
CN108027805B (en) 2012-09-25 2021-12-21 A10网络股份有限公司 Load distribution in a data network
US10002141B2 (en) 2012-09-25 2018-06-19 A10 Networks, Inc. Distributed database in software driven networks
US9338225B2 (en) 2012-12-06 2016-05-10 A10 Networks, Inc. Forwarding policies on a virtual service network
US10205698B1 (en) 2012-12-19 2019-02-12 Amazon Technologies, Inc. Source-dependent address resolution
US9531846B2 (en) 2013-01-23 2016-12-27 A10 Networks, Inc. Reducing buffer usage for TCP proxy session based on delayed acknowledgement
US9900252B2 (en) 2013-03-08 2018-02-20 A10 Networks, Inc. Application delivery controller and global server load balancer
US9992107B2 (en) 2013-03-15 2018-06-05 A10 Networks, Inc. Processing data packets using a policy based network path
US10027761B2 (en) 2013-05-03 2018-07-17 A10 Networks, Inc. Facilitating a secure 3 party network session by a network device
US10038693B2 (en) 2013-05-03 2018-07-31 A10 Networks, Inc. Facilitating secure network traffic by an application delivery controller
US9294391B1 (en) 2013-06-04 2016-03-22 Amazon Technologies, Inc. Managing network computing components utilizing request routing
US10230770B2 (en) 2013-12-02 2019-03-12 A10 Networks, Inc. Network proxy layer for policy-based application proxies
US9942152B2 (en) 2014-03-25 2018-04-10 A10 Networks, Inc. Forwarding data packets using a service-based forwarding policy
US9942162B2 (en) * 2014-03-31 2018-04-10 A10 Networks, Inc. Active application response delay time
US9906422B2 (en) 2014-05-16 2018-02-27 A10 Networks, Inc. Distributed system to determine a server's health
US9992229B2 (en) 2014-06-03 2018-06-05 A10 Networks, Inc. Programming a data network device using user defined scripts with licenses
US9986061B2 (en) 2014-06-03 2018-05-29 A10 Networks, Inc. Programming a data network device using user defined scripts
US10129122B2 (en) 2014-06-03 2018-11-13 A10 Networks, Inc. User defined objects for network devices
US10097448B1 (en) 2014-12-18 2018-10-09 Amazon Technologies, Inc. Routing mode and point-of-presence selection service
US10091096B1 (en) 2014-12-18 2018-10-02 Amazon Technologies, Inc. Routing mode and point-of-presence selection service
US10033627B1 (en) 2014-12-18 2018-07-24 Amazon Technologies, Inc. Routing mode and point-of-presence selection service
US10225326B1 (en) 2015-03-23 2019-03-05 Amazon Technologies, Inc. Point of presence based data uploading
US9819567B1 (en) 2015-03-30 2017-11-14 Amazon Technologies, Inc. Traffic surge management for points of presence
US9887931B1 (en) 2015-03-30 2018-02-06 Amazon Technologies, Inc. Traffic surge management for points of presence
US9887932B1 (en) 2015-03-30 2018-02-06 Amazon Technologies, Inc. Traffic surge management for points of presence
US9832141B1 (en) 2015-05-13 2017-11-28 Amazon Technologies, Inc. Routing based request correlation
US10616179B1 (en) 2015-06-25 2020-04-07 Amazon Technologies, Inc. Selective routing of domain name system (DNS) requests
US10097566B1 (en) 2015-07-31 2018-10-09 Amazon Technologies, Inc. Identifying targets of network attacks
US10581976B2 (en) 2015-08-12 2020-03-03 A10 Networks, Inc. Transmission control of protocol state exchange for dynamic stateful service insertion
US10243791B2 (en) 2015-08-13 2019-03-26 A10 Networks, Inc. Automated adjustment of subscriber policies
US9774619B1 (en) 2015-09-24 2017-09-26 Amazon Technologies, Inc. Mitigating network attacks
US9742795B1 (en) 2015-09-24 2017-08-22 Amazon Technologies, Inc. Mitigating network attacks
US9794281B1 (en) 2015-09-24 2017-10-17 Amazon Technologies, Inc. Identifying sources of network attacks
US10270878B1 (en) 2015-11-10 2019-04-23 Amazon Technologies, Inc. Routing for origin-facing points of presence
US10257307B1 (en) 2015-12-11 2019-04-09 Amazon Technologies, Inc. Reserved cache space in content delivery networks
US10049051B1 (en) 2015-12-11 2018-08-14 Amazon Technologies, Inc. Reserved cache space in content delivery networks
US10348639B2 (en) 2015-12-18 2019-07-09 Amazon Technologies, Inc. Use of virtual endpoints to improve data transmission rates
US10075551B1 (en) 2016-06-06 2018-09-11 Amazon Technologies, Inc. Request management for hierarchical cache
US10110694B1 (en) 2016-06-29 2018-10-23 Amazon Technologies, Inc. Adaptive transfer rate for retrieving content from a server
US9992086B1 (en) 2016-08-23 2018-06-05 Amazon Technologies, Inc. External health checking of virtual private cloud network environments
US10033691B1 (en) 2016-08-24 2018-07-24 Amazon Technologies, Inc. Adaptive resolution of domain name requests in virtual private cloud network environments
US10505961B2 (en) 2016-10-05 2019-12-10 Amazon Technologies, Inc. Digitally signed network address
US10831549B1 (en) 2016-12-27 2020-11-10 Amazon Technologies, Inc. Multi-region request-driven code execution system
US10372499B1 (en) 2016-12-27 2019-08-06 Amazon Technologies, Inc. Efficient region selection system for executing request-driven code
US10938884B1 (en) 2017-01-30 2021-03-02 Amazon Technologies, Inc. Origin server cloaking using virtual private cloud network environments
US10503613B1 (en) 2017-04-21 2019-12-10 Amazon Technologies, Inc. Efficient serving of resources during server unavailability
US11075987B1 (en) 2017-06-12 2021-07-27 Amazon Technologies, Inc. Load estimating content delivery network
US10447648B2 (en) 2017-06-19 2019-10-15 Amazon Technologies, Inc. Assignment of a POP to a DNS resolver based on volume of communications over a link between client devices and the POP
US10742593B1 (en) 2017-09-25 2020-08-11 Amazon Technologies, Inc. Hybrid content request routing system
US10592578B1 (en) 2018-03-07 2020-03-17 Amazon Technologies, Inc. Predictive content push-enabled content delivery network
US10778527B2 (en) 2018-10-31 2020-09-15 Oracle International Corporation Methods, systems, and computer readable media for providing a service proxy function in a telecommunications network core using a service-based architecture
US10862852B1 (en) 2018-11-16 2020-12-08 Amazon Technologies, Inc. Resolution of domain name requests in heterogeneous network environments
US11025747B1 (en) 2018-12-12 2021-06-01 Amazon Technologies, Inc. Content request pattern-based routing system
US11012931B2 (en) 2019-05-24 2021-05-18 Oracle International Corporation Methods, systems, and computer readable media for enhanced signaling gateway (SGW) status detection and selection for emergency calls
US11018971B2 (en) 2019-10-14 2021-05-25 Oracle International Corporation Methods, systems, and computer readable media for distributing network function (NF) topology information among proxy nodes and for using the NF topology information for inter-proxy node message routing
US11528334B2 (en) 2020-07-31 2022-12-13 Oracle International Corporation Methods, systems, and computer readable media for preferred network function (NF) location routing using service communications proxy (SCP)
US11570262B2 (en) 2020-10-28 2023-01-31 Oracle International Corporation Methods, systems, and computer readable media for rank processing for network function selection

Family Cites Families (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5206903A (en) * 1990-12-26 1993-04-27 At&T Bell Laboratories Automatic call distribution based on matching required skills with agents skills
US5828747A (en) * 1997-01-28 1998-10-27 Lucent Technologies Inc. Call distribution based on agent occupancy
US5905793A (en) * 1997-03-07 1999-05-18 Lucent Technologies Inc. Waiting-call selection based on anticipated wait times
US5982873A (en) * 1997-03-07 1999-11-09 Lucent Technologies Inc. Waiting-call selection based on objectives
US6192122B1 (en) * 1998-02-12 2001-02-20 Avaya Technology Corp. Call center agent selection that optimizes call wait times
US6173053B1 (en) * 1998-04-09 2001-01-09 Avaya Technology Corp. Optimizing call-center performance by using predictive data to distribute calls among agents
WO2001039003A1 (en) 1999-11-22 2001-05-31 Speedera Networks, Inc. Method for operating an integrated point of presence server network
US6799214B1 (en) * 2000-03-03 2004-09-28 Nec Corporation System and method for efficient content delivery using redirection pages received from the content provider original site and the mirror sites
US7340532B2 (en) * 2000-03-10 2008-03-04 Akamai Technologies, Inc. Load balancing array packet routing system
AU2000261576A1 (en) 2000-07-11 2002-01-21 Nokia Corporation Method for providing a dns server address list from a server to a client
US6813635B1 (en) * 2000-10-13 2004-11-02 Hewlett-Packard Development Company, L.P. System and method for distributing load among redundant independent stateful world wide web server sites
US20020087722A1 (en) * 2000-12-29 2002-07-04 Ragula Systems D/B/A/ Fatpipe Networks Domain name resolution making IP address selections in response to connection status when multiple connections are present
JP4465577B2 (en) * 2001-04-19 2010-05-19 ソニー株式会社 Information processing apparatus and method, information processing system, recording medium, and program
US8180921B2 (en) * 2001-06-19 2012-05-15 Intel Corporation Method and apparatus for load balancing
US7245632B2 (en) * 2001-08-10 2007-07-17 Sun Microsystems, Inc. External storage for modular computer systems
US6985936B2 (en) * 2001-09-27 2006-01-10 International Business Machines Corporation Addressing the name space mismatch between content servers and content caching systems
JP3780507B2 (en) * 2002-03-14 2006-05-31 日本アイ・ビー・エム株式会社 Session information takeover method, application server, Web site, and program
US7047315B1 (en) * 2002-03-19 2006-05-16 Cisco Technology, Inc. Method providing server affinity and client stickiness in a server load balancing device without TCP termination and without keeping flow states
US20030217147A1 (en) * 2002-05-14 2003-11-20 Maynard William P. Directing a client computer to a least network latency server site
KR100545738B1 (en) 2002-12-21 2006-01-24 한국전자통신연구원 How to create unique domain name based on network device address
KR20040065643A (en) 2003-01-15 2004-07-23 삼성전자주식회사 Method for performing automatic registration of IP address and IP domain name in IP protocol version 6
KR20040082889A (en) 2003-03-20 2004-09-30 이원희 Site Traffic Increasing Method Using Nth Sub Domain Name And System Implementing The Same
US20040210663A1 (en) * 2003-04-15 2004-10-21 Paul Phillips Object-aware transport-layer network processing engine

Also Published As

Publication number Publication date
CN1571388A (en) 2005-01-26
DE602004008693D1 (en) 2007-10-18
EP1473907A2 (en) 2004-11-03
US20040221061A1 (en) 2004-11-04
CN1571388B (en) 2010-04-07
DE602004008693T2 (en) 2008-06-12
US7308499B2 (en) 2007-12-11
EP1473907A3 (en) 2004-11-24
EP1473907B1 (en) 2007-09-05

Similar Documents

Publication Publication Date Title
US7308499B2 (en) Dynamic load balancing for enterprise IP traffic
US8503433B2 (en) Routing methods and systems using ENUM servers
JP5249233B2 (en) IMS service flexible address resolution method
US8681774B2 (en) System and method of routing voice communications via peering networks
US8862740B2 (en) Host-level policies for global server load balancing
US8429221B2 (en) Content request routing method
Cardellini et al. Request redirection algorithms for distributed web systems
US6801952B2 (en) Method and devices for providing network services from several servers
US20090271515A1 (en) Method and Apparatus for Load Balancing in Network Based Telephony Application
GB2342529A (en) Call centre
US20080147885A1 (en) Systems and methods for resolving resource names to ip addresses with load distribution and admission control
JP2008537400A (en) System, network apparatus, method and computer program product for balancing active load using clustered nodes as authoritative domain name servers
CA2443097A1 (en) Alternate routing of voice communication in a packet-based network
US20050044127A1 (en) Dynamic load distribution within a session initiation protocol network
US6850484B1 (en) Packet redirection and message stream management
US8041795B2 (en) Method and arrangement in an internet protocol multimedia subsystem
US9100415B2 (en) On-net direct access to voicemail
US7984110B1 (en) Method and system for load balancing
US7508753B2 (en) Packet redirection and message stream management
JP2000315200A (en) Decentralized load balanced internet server
CA2246133C (en) Method and devices for providing network services from several servers
US8611344B2 (en) Method and apparatus for providing multi-homing to an aggregate endpoint device
Kuzminykh Failover and load sharing in SIP-based IP telephony
Chandra et al. Implementation of a Load Balancer for Instant Messaging over SIP Server Clusters with Improved Response time

Legal Events

Date Code Title Description
EEER Examination request
FZDE Discontinued