CA2295273C - Dynamic resource reallocation - Google Patents

Dynamic resource reallocation Download PDF

Info

Publication number
CA2295273C
CA2295273C CA002295273A CA2295273A CA2295273C CA 2295273 C CA2295273 C CA 2295273C CA 002295273 A CA002295273 A CA 002295273A CA 2295273 A CA2295273 A CA 2295273A CA 2295273 C CA2295273 C CA 2295273C
Authority
CA
Canada
Prior art keywords
resource allocation
resources
ports
directives
traffic
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.)
Expired - Fee Related
Application number
CA002295273A
Other languages
French (fr)
Other versions
CA2295273A1 (en
Inventor
David Randell Ronca
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.)
Mitel Networks Corp
Original Assignee
Mitel Networks Inc
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 Mitel Networks Inc filed Critical Mitel Networks Inc
Publication of CA2295273A1 publication Critical patent/CA2295273A1/en
Application granted granted Critical
Publication of CA2295273C publication Critical patent/CA2295273C/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/50Centralised arrangements for answering calls; Centralised arrangements for recording messages for absent or busy subscribers ; Centralised arrangements for recording messages

Abstract

A resource allocation manager to allocate resources to handle applications in a messaging system includes a database storing a set of resource allocation rules to govern the allocation of resources to applications. A resource allocation engine is responsive to events that potentially effect the manner in which resources are allocated. The resource allocation agent accesses the database and interprets the resource allocation rules in response to events to determine if the events warrant a reallocation of resources to handle applications. Allocation agents are responsive to the resource allocation engine and reallocate resources to handle applications when detected events warrant a reallocation of resources. A method of allocating resources in a messaging system is also provided.

Description

DYNAMIC RESOURCE REALLOCATION
Field of the Invention The present invention relates to messaging systems and, in particular, to allocation of resource usage to various applications in a messaging system.
Background of the Invention Voice messaging systems are common in today's business community.
Most business organizations or enterprises make use of a private branch exchange (PBX) to direct a caller's telephone call to the appropriate extension of the called party. If the called party is unable to answer the telephone call, the telephone call is forwarded to a voice messaging system, which allows the caller to leave a voice message in the mailbox assigned to the called party. Messages left for called parties within the business organization can be retrieved from memory by calling the voice messaging system using a telephone and entering appropriate commands via a touch-tone keypad. Retrieved messages can be played, forwarded or deleted. An example of a voice messaging system of this nature is the Series 6 sold by Mitel Corporation of Ottawa, Ontario, Canada.
In addition to voice messages, communications within business organizations are also stored in facsimile and text formats. In the past, separate messaging systems have been used to handle these different types of communications.
Unfortunately, prior art messaging systems designed to handle one type of communication have not provided any means to interact with messaging systems handling other types of communications. This has required users to access each messaging system individually to retrieve messages and has required business organizations to maintain and manage multiple messaging systems separately. As a result, it has been necessary to establish separate accounts, address lists and message mailboxes in each messaging system for the various users in the business organizations.
More recently, attempts have been made to interconnect different messaging systems to provide access to different types of messages from a single point. For example, U.S. Patent No. 5,349,636 to Irribarren discloses a system and method for voice mail systems and interactive voice response (IVR) systems.
The Irnbarren system includes a voice message system and a text message system
-2-integrated via a network, which coordinates the functions of each individual message system. A user may access messages stored in the voice message system and in the text message system via a single telephone call. Although this system allows access to different types of messages, the voice message and text message systems require separate management.
The current trend is to integrate these various messaging systems to allow users to access all types of communications once a connection is made to the messaging system. To that end, unified messaging systems have been developed to provide users access to virtually all of their communications. Messaging systems of this nature store all messages for entities within the enterprise at a common location.
The entities may be individuals, groups, departments, or any appropriate logical organizations. Users accessing the messaging system via a telephone, desktop computer or other communication device have access to all of their messages regardless of message type and regardless of the type of communication device used to access the messaging system. Appropriate message translators such as text-to-speech (TTS) converters, speech-to-text (SST) converters etc. are included to enable users to retrieve messages stored in formats not supported by the communication devices used to access the messaging system.
Unified messaging systems include both incoming (messaging, auto-attendant, etc.) and outgoing (paging, fax delivery, call-me, etc.) applications. These incoming and outgoing applications run either on separate or shared ports or resources. Using separate ports for applications does not make particularly good use of available hardware but guarantees resource availability. Using shared ports, makes good use of available hardware but does not provide for guaranteed resource availability. Typically, the administrator of the messaging system statically assigns separate and shared ports to the applications within the messaging system based on a traffic model for the messaging system. Unfortunately, statically assigning ports to the applications can lead to a number of problems depending on traffic.
Consider a case of an eight (8) port messaging system having four ports dedicated to handle only incoming calls, two shared ports capable of handling any application, and two shared ports dedicated to handle only outgoing applications.
The two shared ports and two outgoing application ports provide four ports for fax
-3-resources, which are available on a first-come, first-served basis. With this static port allocation, a number of problems can arise depending on traffic. If, for example, a large number of fax and page delivery jobs are pending and if two ports are being used by an outgoing application such as call-me and one port is being used for normal messaging, then only two ports are available to handle the fax and page delivery jobs even thought three of the incoming call ports are idle. As another example, if there are no fax or page delivery jobs pending but six of the ports are being used for normal messaging, the two outgoing application ports will be available to handle any upcoming fax or page delivery jobs. Hence, a caller to the messaging system will get a busy tone since no ports are available to handle the incoming call even though the two outgoing application ports are idle. As will be appreciated, statically assigning ports to applications can lead to poor resource allocation especially if unexpected traffic situations arise.
Thus, there is a need for improvements to resource allocation in messaging systems.
Summary of the Invention The present invention provides improved resource allocation to applications of a messaging system. By monitoring the messaging system, resource allocation to applications can be performed dynamically so that better and more effective utilization of the resource can be had. The improved resource allocation leads to more responsive servicing of applications (e.g., incoming and outgoing applications) by the messaging systems.
According to one aspect of the present invention there is provided a method for allocating resources to handle applications in a messaging system comprising the steps of:
establishing a set of resource allocation rules governing the allocation of resources to applications;
monitoring the messaging system to detect events that potentially effect the manner in which resources of said messaging systems are allocated;
-4-accessing the resource allocation rules in response to detected events to determine if said detected events warrant a reallocation of resources to handle applications;
generating resource allocation directives when said detected events warrant a reallocation of resources; and reallocating resources to handle applications in accordance with said resource allocation directives, wherein said resource allocation directives include non-interrupting and interrupting resource allocation directives, reallocation of said resources occurring immediately in response to interrupting resource allocation directives and occurring after completion of current tasks handled by the resources to be reallocated in response to said non-interrupting resource allocation directives.
In one embodiment, the resource allocation manager further comprises a plurality of event detection agents to monitor the messaging system to detect the events and to communicate the events to the resource allocation engine. The event detection agents include a traffic level agent to detect traffic levels. The event detection agents can also include a system clock agent to detect particular times of the day, which is useful for detecting traffic peak periods and non-peak periods or business and non-business hours.
According to another aspect of the present invention there is provided a resource allocation manager to allocate resources to handle applications in a messaging system, said resource allocation manager comprising:
a database storing a set of resource allocation rules governing the allocation of resources to applications;
a resource allocation engine responsive to events that potentially effect the manner in which resources are allocated, said resource allocation agent accessing said database and interpreting the resource allocation rules in response to events to determine if said events warrant a reallocation of resources to handle applications, said resource allocation engine generating resource allocation directives when said detected events warrant a reallocation of resources; and allocation agents responsive to said resource allocation engine and reallocating resources to handle applications wherein said resource allocation directives include non-interrupting and interrupting resource allocation directives, -4a-reallocation of said resources occurring after completion of current tasks handled by the resources to be reallocated in response to said non-interrupting resource allocation directives.
According to another aspect of the present invention there is provided a method for allocating ports of a messaging system to incoming and outgoing communication facilities comprising the steps o~
establishing a set of resource allocation rules governing the allocation of said ports to communicate facilities of said messaging system, at least one of said ports being dedicated to a specific communication facility during a predetermined period of the day;
monitoring the messaging system to detect events that effect the manner by which ports are allocated to said communication facilities;
accessing the resource allocation rules to determine how said ports are to be reallocated in response to said detected events and generating resource allocation directives, said resource allocation directives including interrupting and non-interrupting resource allocation directives; and reallocating ports to accommodate needs of said communication facilities in accordance with said resource allocation directives.
The present invention provides advantages in that resources are allocated to applications dynamically to accommodate changes in messaging system -$-requirements. As a result, situations where some resources are idle yet at the same time resources are unavailable to handle other applications, occur to a lesser extent than in conventional messaging systems implementing a static resource allocation methodology. In high capacity messaging systems, a rules-based approach for allocating resources to applications provides for the reallocation of a significant number of resources in an intelligent manner.
Brief Description of the Drawings An embodiment of the present invention will now be described more fully with reference to the accompanying drawings in which:
Figure 1 is a schematic drawing of a resource allocation manager in accordance with the present invention; and Figure 2 is a representative use case showing traffic related resource reallocation.
1$
Detailed Description of the Invention The present invention relates to a messaging system including a resource allocation manager to allocate resources dynamically to applications.
The present invention can be implemented in virtually any type of messaging system where applications are allocated resources such as voice messaging systems, interactive voice response (IVR) systems, voice and text messaging systems, and unified messaging systems.
Turning now to Figure 1, a resource allocation manager 10 for a messaging system is shown. As can be seen, the resource allocation manager 10 2$ includes a resource allocation engine 12. The resource allocation manager 10 can, for example, run on an allocation server. The resource allocation engine 12 is responsive to trigger events of interest generated by trigger event agents 14 and communicates with a rules database 16. The rules database 16 stores resource allocation rules. The resource allocation engine 12 also communicates with a plurality of allocation agents 26. Each allocation agent 26 is associated with a respective port of the messaging system. The allocation agents 26 assign ports to applications within the messaging system in response to resource allocation directives 28 generated by the resource allocation engine 12. The resource allocation directives 28 may be of the interrupting or non-interrupting type. A non-interrupting directive takes effect after completion of a current task or immediately if no task is in progress. An interrupting directive takes effect immediately regardless of the resource status.
The resource allocation rules stored in the rules database 16 determine how ports are to be allocated to handle applications and are typically specified by a messaging system administrator based on site requirements and traffic patterns. The resource allocation rules may include application usage restrictions based on time of day, application type, call traffic, etc. As will be appreciated, message traffic in a messaging system is unpredictable. For example, a large number of incoming faxes and telephone calls may occur at the same time requiring more ports than are currently allocated to handle this type of traffic. As a result, it may be necessary to allocate more ports capable of handling incoming applications to deal with the unexpected traffic. By using the resource allocation rules, port allocation can be varied based on traffic patterns and on current messaging system traffic.
Therefore, if the messaging system is experiencing heavy incoming traffic and there are few incoming application ports available, a predetermined number of shared ports can be reassigned to handle the incoming applications. Likewise, if incoming traffic is low, the shared ports can be re-assigned to allow use by other applications.
Table 1 below shows rule definitions for a thirty (30) port messaging system having eight (8) facsimile ports.

Table 1 Group Members Resource Allocation Rules 1 Voice Ports: 1- 6 All Hours:

Fax Ports: 1- 2 Dedicate to incoming applications 2 Voice Ports: 7 -12 Peals Hours:

Fax Ports: 3 - 4 Dedicate to incoming applications Non-Peak Hours:

If incoming traffic is higher than n, dedicate to incoming applications.

Otherwise use as needed 3 Voice Ports: 13 - All Hours:

Fax Ports: 5 If incoming traffic is higher than n, dedicate to incoming applications.

Otherwise use as needed.

4 Voice Ports: 21, All Hours:

F ax Ports: 6 Dedicate to outgoing applications.
5 Fax Ports: 7, 8 Business Hours:

Dedicate to incoming applications for VIP class users:

Non-business Hours:

As needed.

In this embodiment, the ports of the messaging system are divided into five groups.
Voice ports 1 to 6 and fax ports 1 and 2 form group 1. Voice ports 7 to 12 and fax ports 3 and 4 form group 2. Voice ports 13 to 20 and fax port 5 form group 3.
Voice ports 21 and 22 and fax port 6 form group 4. Fax ports 7 and 8 form group S.
Assigned to each group of ports are resource allocation rules. As can be seen, for group 1, the resource allocation rules dedicate the ports to normal messaging (i.e., incoming applicatioais) for all hours. For group 2, the resource allocation rules dedicate the ports to normal messaging during peak hours only. As a result, at non--$-peak hours, the ports can be used as needed and therefore, other applications including outgoing applications can be allocated to the ports of group 2.
However, during non-peak hours, if messaging traffic is higher than a predetermined threshold n, then the ports are dedicated to normal messaging. For group 3, regardless of the time of day, if messaging traffic is higher than the predetermined threshold n, the resource allocation rules dedicate the ports to normal messaging. Otherwise, the ports of group 3 are used as needed. For group 4, the resource allocation rules dedicate the ports to outgoing applications only. For group 5, the resource allocation rules dedicate the ports to any application called by VIP class users during business hours.
During non-business hours, the ports of group 5 are used as needed.
As mentioned above, in order to determine the resource needs of the messaging system, the resource allocation engine 12 responds to trigger events generated by the trigger event agents 14 that effect the manner in which resources are allocated to applications to make better use of messaging system resources.
Examples of trigger event agents 14 are shown in Figure 1 and include a CPU utilization trigger event agent 18, a resource usage trigger event agent 20, a call traffic trigger event agent 22, and a system clock trigger event agent 24.
The CPU trigger event agent 18 generates CPU trigger events when CPU utilization is not available or not at an optimal rate. The resource usage trigger event agent 20 generates resource usage trigger events when resources are not available to handle applications and it is necessary to re-assign ports to handle the applications. The call traffic trigger event agent 22 generates call traffic events when the amount of incoming or outgoing traffic is higher or lower than a predetermined threshold level. In the case of incoming or outgoing traffic above the threshold level, the call traffic trigger events signify a need for additional port allocation to handle the traffic. In the case of incoming or outgoing traffic below the threshold level, the call traffic trigger events signify additional port availability. The system clock trigger event agent 24 generates system clock trigger events at specific times of the day to signal peak and non-peak hours as well as business and non-business hours.
During operation, the resource allocation engine 12 awaits receipt of trigger events from the trigger event agents 14. The resource allocation engine 12 in response to the trigger events accesses the rules database 16. Using the trigger events, the resource allocation engine 12 interprets the resource allocation rules and generates resource allocation directives 28. The resource allocation directives 28 are in turn conveyed to the appropriate allocation agents 26. The allocation agents 26 in response to the resource allocation directives 28 condition their associated ports to handle applications specified by the resource allocation rules and satisfy the messaging system requirements. Since the resource allocation engine 12 is responsive to non-traffic related trigger events, traffic level is not the only criteria used to allocate ports.
Turning now to Figure 2, an example of reassignment of resource allocation by the resource allocation manager 10 in response to a call traffic trigger event generated during peak hours is illustrated as a representative use case.
In this case, high traffic above the threshold level is detected by the call traffic trigger event agent 22. The call traffic trigger event agent 22 in turn generates a call traffic trigger event 30 and conveys the call traffic event to the resource allocation engine 12. When 1 S the resource allocation engine 12 receives the call traffic trigger event, the resource allocation engine 12 accesses the resource allocation rules database 16 and checks 32 the resource allocation rules therein. Using the rules in Table 1, the resource allocation engine 12 generates a resource allocation directive 34 for the allocation agents 26 handling the ports of group 3. When the resource allocation agents receive the resource allocation directive 34, they condition 36 their ports so that they become allocated to handle incoming applications. The resource allocation agents 26 also send an acknowledgment 38 to the resource allocation engine 12 confirming the re-assignment of the group 3 ports.
As will be appreciated, by providing rules governing the allocation of resources to applications based on specified events, resource allocation can be handled intelligently and dynamically to deal with messaging system needs. As a result, situations where resources are unavailable for certain applications while other resources remain idle are avoided. To illustrate the above, consider an eight port messaging system including the present resource allocation manager 10. In this example, the rules database 16 includes resource allocation rules, which specify the following port assignments:

-lU-two voice ports dedicated to handle incoming calls only;
during peak business hours, six voice ports and two fax ports dedicated to handle messaging applications;
under heavy messaging traffic conditions, all available voice ports and fax ports dedicated to handle messaging applications; and under light incoming messaging traffic, additional voice ports and fax ports allocated to handle outgoing applications depending on the number of pending jobs.
Consider now the scenario where outside of business hours, a large number of outgoing faxes and page delivery jobs are pending, three ports are being used by outgoing applications and one port is being used by a normal messaging application. In this situation, based on the above resource allocation rules, the resource allocation manager 10 reallocates the two available voice ports and the available fax ports to handle the pending fax and page delivery jobs. Only two of the four voice ports are reallocated since the first resource allocation rule requires that two ports always be dedicated to handle incoming calls.
Now consider the scenario where there are no outgoing fax or page delivery jobs pending and six ports are being used for incoming applications.
In this situation, based on the above resource allocation rules, when higher than normal incoming traffic is detected, the resource allocation manager 10 allocates all of the ports to handle incoming applications minimizing the chance that a caller receives a busy signal.
Finally, consider the scenario where a number of outgoing fax and page delivery jobs are pending and four ports are being used for fax delivery.
Depending on the time of day, the resource allocation manager 10 will handle resource allocation differently. For example, during peak business hours, the resource allocation manager 10 would re-assign only two ports to handle the fax delivery jobs since the second rule specifies that six ports must be dedicated to handle incoming voice calls applications. However, outside of peak hours, the resource allocation manager 10 would re-assign additional ports to handle the fax delivery jobs.
As will be appreciated, the resource allocation manager 10 allocates resources to applications dynamically to accommodate changes in messaging system requirements. As a result, situations where ports are idle yet resources are unavailable to handle other applications occur to a lesser extent than in conventional messaging systems implementing a static resource allocation methodology. In high capacity messaging systems, the rules-based approach for allocating resources to applications provides for the reallocation of a significant number of resources in an intelligent manner.
If desired, a learning engine including artificial intelligence may also be included in the resource allocation manager to monitor traffic patterns and resource usage within the messaging system and modify automatically the resource allocation rules over time.
Although particular trigger event agents are shown in Figure 1, those of skill in the art will appreciate that these trigger event agents are shown for illustrative purposes. The resource allocation manager 10 may be responsive to more or fewer trigger event agents. Also, although the trigger event agents are described as providing trigger events to the resource allocation engine 12, it should be appreciated that the resource allocation engine can poll the trigger event agents 14 for trigger events. Alternatively, a combination of polling and event based trigger event generation can be used.
Also, although the resource allocation manager 10 has been described as being used in a messaging system to allocate resources to handle applications, those of skill in the art will appreciate that the resource allocation manager may also be used to limit availability of certain types of resources to users, or classes of users.
For example, in order to provide load stabilization, the resource allocation manager could disable/limit certain activities during high incoming traffic loads allowing resources to be allocated to handle more important tasks.
The invention can also be embodied as computer readable code on a computer readable medium. The computer readable medium is any data storage device that can store data which can be thereafter be read by a computer system.
Examples of the computer readable medium include read-only memory, random-access memory, CD-ROMs, magnetic tape, optical data storage devices. The computer readable medium can also be distributed over a network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
Although a preferred embodiment of the present invention has been described, those of skill in the art will appreciate that variations and modifications may be made without departing from the spirit and scope thereof as defined by the appended claims.

Claims (26)

What is claimed is:
1. A method for allocating resources to handle applications in a messaging system comprising the steps of:
establishing a set of resource allocation rules governing the allocation of resources to applications;
monitoring the messaging system to detect events that potentially effect the manner in which resources of said messaging systems are allocated;
accessing the resource allocation rules in response to detected events to determine if said detected events warrant a reallocation of resources to handle applications;
generating resource allocation directives when said detected events warrant a reallocation of resources; and reallocating resources to handle applications in accordance with said resource allocation directives, wherein said resource allocation directives include non-interrupting and interrupting resource allocation directives, reallocation of said resources occurring immediately in response to interrupting resource allocation directives and occurring after completion of current tasks handled by the resources to be reallocated in response to said non-interrupting resource allocation directives.
2. A method of claim 1 wherein said detected events include a change in traffic level.
3. A method of claim 2 wherein said detected events include an increase in traffic level beyond a first threshold value.
4. A method of claim 3 wherein said detected events include a decrease in traffic level below a second threshold value.
5. A method of claim 3 wherein said detected events include particular times of day.
6. A method of claim 5 wherein said particular times of day identify traffic peak periods and non-peak periods or business and non-business hours.
7. A method of claim 1 further comprising monitoring traffic patterns and resource usage over time and adjusting the resource allocation rules in accordance therewith.
8. A method of claim 7 wherein said resource allocation rules are adjusted automatically.
9. A method of claim 1 wherein during said monitoring, event agents are polled to detect said events.
10. A resource allocation manager to allocate resources to handle applications in a messaging system, said resource allocation manager comprising:
a database storing a set of resource allocation rules governing the allocation of resources to applications;
a resource allocation engine responsive to events that potentially effect the manner in which resources are allocated, said resource allocation agent accessing said database and interpreting the resource allocation rules in response to events to determine if said events warrant a reallocation of resources to handle applications, said resource allocation engine generating resource allocation directives when said detected events warrant a reallocation of resources; and allocation agents responsive to said resource allocation engine and reallocating resources to handle applications wherein said resource allocation directives include non-interrupting and interrupting resource allocation directives, reallocation of said resources occurring immediately in response to interrupting resource allocation directives and occurring after completion of current tasks handled by the resources to be reallocated in response to said non-interrupting resource allocation directives.
11. A resource allocation manager as defined in claim 10 further comprising:
a plurality of event detection agents monitoring said messaging system to detect said events.
12. A resource allocation manager as defined in claim 11 wherein said event detection agents notify said resource allocation engine of said events upon detection thereof.
13. A resource allocation manager as defined in claim 12 wherein said event detection agents include a traffic agent to monitor traffic level.
14. A resource allocation manager as defined in claim 13 wherein said traffic agent detects at least one of an increase in traffic level beyond a predetermined threshold value and a decrease in traffic level below a predetermined threshold value.
15. A resource allocation manager as defined in claim 13 wherein said event detection agents include a system clock agent to detect particular times of the day.
16. A resource allocation manager as defined in claim 15 wherein said system clock agent detects traffic peak periods and non-peak periods or business and non-business hours.
17. A resource allocation manager as defined in any one of claims 10 to 16 further comprising:
a learning engine monitoring traffic patterns and resource usage over time and adjusting the resource allocation rules in accordance therewith.
18. A resource allocation manager as defined in claim 17 wherein said learning engine adjusts said resource allocation rules automatically.
19. A method for allocating ports of a messaging system to incoming and outgoing communication facilities comprising the steps of:
establishing a set of resource allocation rules governing the allocation of said ports to communicate facilities of said messaging system, at least one of said ports being dedicated to a specific communication facility during a predetermined period of the day;
monitoring the messaging system to detect events that effect the manner by which ports are allocated to said communication facilities;
accessing the resource allocation rules to determine how said ports are to be reallocated in response to said detected events and generating resource allocation directives, said resource allocation directives including interrupting and non-interrupting resource allocation directives; and reallocating ports to accommodate needs of said communication facilities in accordance with said resource allocation directives.
20. The method of claim 19 wherein a plurality of ports are dedicated a specific communication facility during a predetermined period of the day.
21. The method of claim 20 wherein at least some of said ports are dedicated to a specific communication facility at all times and are not reallocated in response to resource allocation directives.
22. The method of any one of claims 19 to 21 wherein said ports include both voice and facsimile ports.
23. The method of claim 22 wherein said detected events include a change in communication traffic level.
24. The method of claim 23 wherein said detected events include an increase in traffic level beyond a first threshold value and a decrease in traffic level below a second threshold value.
25. The method of claim 22 further comprising the step of monitoring communication traffic patters and port usage over time and adjusting the resource allocation rules in accordance therewith.
26. The method of claim 22 wherein selected ones of said voice and facsimile ports are dedicated to specific communication facilities at all times and wherein selected others of said voice and facsimile ports are dedicated to specific communication facilities at specified periods of the day.
CA002295273A 1999-03-01 2000-01-12 Dynamic resource reallocation Expired - Fee Related CA2295273C (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/259,986 US6745221B1 (en) 1999-03-01 1999-03-01 Dynamic resource reallocation
US09/259,986 1999-03-01

Publications (2)

Publication Number Publication Date
CA2295273A1 CA2295273A1 (en) 2000-09-01
CA2295273C true CA2295273C (en) 2003-07-22

Family

ID=22987331

Family Applications (1)

Application Number Title Priority Date Filing Date
CA002295273A Expired - Fee Related CA2295273C (en) 1999-03-01 2000-01-12 Dynamic resource reallocation

Country Status (3)

Country Link
US (1) US6745221B1 (en)
CA (1) CA2295273C (en)
GB (1) GB2347580B (en)

Families Citing this family (57)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
NL1011788C2 (en) * 1999-04-14 2000-10-17 Koninkl Kpn Nv Operating system for an IC network.
US8661539B2 (en) * 2000-07-10 2014-02-25 Oracle International Corporation Intrusion threat detection
US7124203B2 (en) * 2000-07-10 2006-10-17 Oracle International Corporation Selective cache flushing in identity and access management systems
US7194764B2 (en) * 2000-07-10 2007-03-20 Oracle International Corporation User authentication
US9038170B2 (en) 2000-07-10 2015-05-19 Oracle International Corporation Logging access system events
US7464162B2 (en) * 2000-07-10 2008-12-09 Oracle International Corporation Systems and methods for testing whether access to a resource is authorized based on access information
US7249369B2 (en) * 2000-07-10 2007-07-24 Oracle International Corporation Post data processing
US7134137B2 (en) * 2000-07-10 2006-11-07 Oracle International Corporation Providing data to applications from an access system
US7080077B2 (en) * 2000-07-10 2006-07-18 Oracle International Corporation Localized access
US7185364B2 (en) * 2001-03-21 2007-02-27 Oracle International Corporation Access system interface
US7433311B1 (en) * 2001-03-19 2008-10-07 Cisco Technology, Inc. Methods and apparatus for allocating resources in a communications system
US8775645B2 (en) * 2001-11-13 2014-07-08 Cvidya Networks Ltd. System and method for generating policies for a communication network
US7225256B2 (en) 2001-11-30 2007-05-29 Oracle International Corporation Impersonation in an access system
ES2250613T3 (en) * 2002-01-09 2006-04-16 Telefonaktiebolaget Lm Ericsson (Publ) METHOD AND EQUIPMENT OF CREDIT MANAGEMENT FOR ACCESS IN A TELECOMMUNICATIONS NETWORK.
US7230745B1 (en) 2002-04-08 2007-06-12 Captaris, Inc. Document transmission and routing with recipient control, such as facsimile document transmission and routing
EP1479215A1 (en) * 2002-06-05 2004-11-24 Matsushita Electric Industrial Co., Ltd. Call answering system in a voice messaging system
US7233786B1 (en) 2002-08-06 2007-06-19 Captaris, Inc. Providing access to information of multiple types via coordination of distinct information services
US7437728B2 (en) * 2003-06-12 2008-10-14 Microsoft Corporation System and method for CPU bandwidth allocation
CA2443454A1 (en) * 2003-09-11 2005-03-11 Teamplate Inc. Data binding method in workflow system
CA2451164C (en) 2003-09-11 2016-08-30 Teamplate Inc. Customizable components
US7260393B2 (en) * 2003-09-23 2007-08-21 Intel Corporation Systems and methods for reducing communication unit scan time in wireless networks
US7904487B2 (en) 2003-10-09 2011-03-08 Oracle International Corporation Translating data access requests
US7882132B2 (en) 2003-10-09 2011-02-01 Oracle International Corporation Support for RDBMS in LDAP system
EP1632083A4 (en) * 2003-11-05 2007-05-02 Nice Systems Ltd Apparatus and method for event-driven content analysis
WO2005089239A2 (en) * 2004-03-13 2005-09-29 Cluster Resources, Inc. System and method of providing a self-optimizing reservation in space of compute resources
US7925755B2 (en) 2004-12-30 2011-04-12 International Business Machines Corporation Peer to peer resource negotiation and coordination to satisfy a service level objective
US8484334B2 (en) * 2005-03-31 2013-07-09 Sap Aktiengesellschaft Allocating resources based on rules and events
US8336054B2 (en) * 2006-07-20 2012-12-18 Hewlett-Packard Development Company, L. P. System and method for allocating capacity of shared resources to a workload
US8112756B2 (en) * 2006-07-20 2012-02-07 Hewlett-Packard Development Company, L.P. System and method for evaluating a workload and its impact on performance of a workload manager
US9135074B2 (en) * 2005-05-19 2015-09-15 Hewlett-Packard Development Company, L.P. Evaluating performance of workload manager based on QoS to representative workload and usage efficiency of shared resource for plurality of minCPU and maxCPU allocation values
US8392927B2 (en) * 2005-05-19 2013-03-05 Hewlett-Packard Development Company, L. P. System and method for determining a partition of a consumer's resource access demands between a plurality of different classes of service
US8645175B1 (en) 2005-07-12 2014-02-04 Open Text S.A. Workflow system and method for single call batch processing of collections of database records
US20070177195A1 (en) * 2005-10-31 2007-08-02 Treber Rebert Queue processor for document servers
US7653185B2 (en) * 2005-10-31 2010-01-26 Open Text Corporation Universal document transport
US20230319159A1 (en) * 2005-10-31 2023-10-05 Treber Rebert Queue processor for document servers
US8688813B2 (en) 2006-01-11 2014-04-01 Oracle International Corporation Using identity/resource profile and directory enablers to support identity management
CA2640739A1 (en) * 2006-01-31 2007-09-08 Captaris, Inc. Workflow applications
WO2007134265A2 (en) 2006-05-12 2007-11-22 Captaris, Inc. Workflow data binding
US7613809B2 (en) * 2006-05-30 2009-11-03 Intel Corporation Supporting ephemeral ports in a virtualized environment
US8046765B2 (en) * 2006-07-25 2011-10-25 Hewlett-Packard Development Company, L.P. System and method for determining allocation of resource access demands to different classes of service based at least in part on permitted degraded performance
CA2659607C (en) 2006-08-02 2017-12-05 Captaris, Inc. Configurable document server
US8065682B2 (en) * 2007-02-27 2011-11-22 Microsoft Corporation Enforcing system resource usage limits on query requests based on grouping query requests into workgroups and assigning workload groups to resource pools
FR2919084A1 (en) * 2007-07-17 2009-01-23 Open Plug Sa METHOD FOR MANAGING SHARED RESOURCES OF A COMPUTER SYSTEM AND SUPERVISOR MODULE FOR IMPLEMENTATION, AND COMPUTER SYSTEM COMPRISING SUCH A MODULE
US20090128861A1 (en) * 2007-09-09 2009-05-21 Xpedite Systems, Llc Systems and Methods for Communicating Multimodal Messages
US20090089325A1 (en) 2007-09-28 2009-04-02 Rockwell Automation Technologies, Inc. Targeted resource allocation
US10003701B2 (en) 2008-01-30 2018-06-19 Xpedite Systems, Llc Systems and methods for generating and communicating enhanced portable document format files
US20090222832A1 (en) * 2008-02-29 2009-09-03 Dell Products, Lp System and method of enabling resources within an information handling system
US20100033433A1 (en) * 2008-08-08 2010-02-11 Dell Products, Lp Display system and method within a reduced resource information handling system
US8134565B2 (en) * 2008-08-08 2012-03-13 Dell Products, Lp System, module and method of enabling a video interface within a limited resource enabled information handling system
US8370673B2 (en) * 2008-10-30 2013-02-05 Dell Products, Lp System and method of utilizing resources within an information handling system
US9880877B2 (en) * 2009-01-22 2018-01-30 International Business Machines Corporation Methods for rule-based dynamic resource adjustment for upstream and downstream processing units in response to an intermediate processing unit event
US8661024B2 (en) * 2010-01-21 2014-02-25 Oracle International Corporation Database query resource management using select statement condition
US9280391B2 (en) 2010-08-23 2016-03-08 AVG Netherlands B.V. Systems and methods for improving performance of computer systems
WO2013048986A1 (en) * 2011-09-26 2013-04-04 Knoa Software, Inc. Method, system and program product for allocation and/or prioritization of electronic resources
US10349342B2 (en) 2013-08-22 2019-07-09 Fujitsu Connected Technologies Limited System information broadcast in machine-to-machine radio access systems
US9563475B2 (en) * 2014-09-30 2017-02-07 International Business Machines Corporation Merging connection pools to form a logical pool of connections during a preset period of time thereby more efficiently utilizing connections in connection pools
US10602523B2 (en) * 2016-12-22 2020-03-24 Verizon Patent And Licensing Inc. Allocation of network resources based on antenna information and/or device type information

Family Cites Families (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4959854A (en) 1990-01-26 1990-09-25 Intervoice Inc. Apparatus and method for automatically reconfiguring telephone network resources
US5530740A (en) 1991-10-28 1996-06-25 Contigram Communications Corporation System and method for integrating voice, facsimile and electronic mail data through a personal computer
US5349636A (en) 1991-10-28 1994-09-20 Centigram Communications Corporation Interface system and method for interconnecting a voice message system and an interactive voice response system
US5737395A (en) 1991-10-28 1998-04-07 Centigram Communications Corporation System and method for integrating voice, facsimile and electronic mail data through a personal computer
US5329579A (en) 1992-07-27 1994-07-12 At&T Bell Laboratories Modular adjunct processor made of identical multi-function modules adaptable under direction of one of them to perform any of the adjunct-processor functions
DE69536008D1 (en) 1994-06-27 2009-11-12 Intel Corp Apparatus and method for distributing call processing tools
US5774668A (en) * 1995-06-07 1998-06-30 Microsoft Corporation System for on-line service in which gateway computer uses service map which includes loading condition of servers broadcasted by application servers for load balancing
US5673253A (en) * 1996-02-29 1997-09-30 Siemens Business Communication Systems Dynamic allocation of telecommunications resources
US5841966A (en) 1996-04-04 1998-11-24 Centigram Communications Corporation Distributed messaging system
US6304549B1 (en) * 1996-09-12 2001-10-16 Lucent Technologies Inc. Virtual path management in hierarchical ATM networks
US6335927B1 (en) * 1996-11-18 2002-01-01 Mci Communications Corporation System and method for providing requested quality of service in a hybrid network

Also Published As

Publication number Publication date
GB2347580A (en) 2000-09-06
US6745221B1 (en) 2004-06-01
GB9919242D0 (en) 1999-10-20
CA2295273A1 (en) 2000-09-01
GB2347580B (en) 2003-08-27

Similar Documents

Publication Publication Date Title
CA2295273C (en) Dynamic resource reallocation
US6775378B1 (en) Blended agent contact center
CA2071300C (en) Method and system for the efficient distribution of messages utilizing a data processing system
US6996614B2 (en) Resource allocation in data processing systems
JP3762179B2 (en) Request distribution method and apparatus
US6418201B1 (en) Multiple platform voice processing system with optimized resource allocation
US6681010B1 (en) Methods, systems and computer program products for automatic task distribution
US11831809B2 (en) Limiting contact in a networked contact center environment
EP0567294A2 (en) Multi-system network addressing
US20130010947A1 (en) System and Method of Determining Call Treatment of Repeat Calls
US8036372B2 (en) Methods and apparatus for dynamically reallocating a preferred request to one or more generic queues
US20080225872A1 (en) Dynamically defining queues and agents in a contact center
KR20000076638A (en) Dynamically allocating server resources to competing classes of work based upon achievement of service goals
CN110290281B (en) Outbound method, system, electronic device and medium
CN1154334C (en) Distributed IP-pool in GPRS
US5412781A (en) Method and arrangement of buffer allocation in communication systems by employing fixed and dynamic buffer allocation functions
US7376738B2 (en) Method of dynamically allocating usage of a shared resource
US20020073192A1 (en) Distributed communication system
CN105450878B (en) The distribution method and distribution system of resource of attending a banquet code
CN105491253A (en) Resource distribution method and system for call center
US6744732B1 (en) Dynamic throughput allocation in a converged voice/data services network interface
US7720087B2 (en) Method and system for channel management in a voice response system
EP1107554B1 (en) Method and system for adaptively allocating call-related tasks
EP0820182A2 (en) Dynamic mailbox messaging system
US6381252B1 (en) Method and system for managing communication resources

Legal Events

Date Code Title Description
EEER Examination request
MKLA Lapsed

Effective date: 20200113