The present invention relates to data management and more particularly relates to a method and apparatus for adding a database partition.
Increased reliance on computers and networks has likewise increased the need for high-availability and scalability of such computers and networks. One specific example is wireless telecommunications. In a wireless telecommunication network, the network must be available twenty-four hours a day, creating the need for maintenance and upgrades to be performed while the network is running “hot”, and with minimal disruption in quality of service. As new services and/or subscribers are continuously added to the network, existing database hardware will eventually need to be replaced and upgraded. Data from existing hardware must then be migrated to the new hardware, again with minimal disruption in quality of service.
An aspect of the specification provides a method for adding a database partition comprising:
determining an existing number of partitions;
examining each existing partition to determine which portion of each existing partition is to be transferred according to a minimally progressive hash operation;
adding a new partition; and,
transitioning portions of existing partitions to said new partition according to the determinations made during said examining step.
The hashing operation is selected from a class of partitioning algorithms that substantially maintain a maximum, or substantially maximum, consistency between consecutive partition sizes.
The method can be repeated until a desired number of partitions have been added.
Another aspect of the specification provides a computer readable medium that stores programming instructions that implements the method.
Referring now to
Applications 58 can be any type of application that is currently known (or is developed in the future) that would serve data stored in databases 62 to SCPs 54. A well known example of an application 58 is an application to route 1-800-numbers to a traditional area code and phone number. Other examples for applications 58 include customer resource management, cross-service bundling, location services and rating, Virtual Private Networking, Prepaid billing, Missed Call Return, Loyalty Reward and Promotion Programs, Fraud Management, Policy Management, Call Screening and Redirection, and Subscriber Profile Management.
Databases 62 include the infrastructure to store, retrieve and manage data, including hardware to store the data and a database application layer, such as the Structured Query Language (“SQL”) or the like, to interface between each database 62 and each application 58.
Referring now to
In the present embodiment, database 62P-1 represents a single partition and that database 62S-1 represents a single partition. Thus, to give a concrete example of the performance of method 100, it will be assumed that database partition 62P-1 is full and that a second database partition 62P-2 is being added to database partition 62P-1. Method 100 can be implemented on any suitable computing environment (e.g. a server) with physical connections to each database partition 62P in order to examine the existing partitions 62P and determine how to move data on the existing partition(s) to the new partition.
Beginning at step 105 in
Next, at step 115, the new partition would be added. In the present example database partition 62P-2 would become physically and operationally attached to and integrated with partition 62P-1, such that each application 58 would perceive both partitions 62P-1 and 62P-2 to be a single database 62P, such that each application 58 would continue to interact with partitions 62P in the same manner as one partition 62P.
Next, at step 115, the new partition would be added. In the present example database partition 62P-2 would become physically attached to partition 62P-1. Next, at step 120, portions of the existing database will be ported from the existing partition(s) to the new partition in accordance with the determinations made by hashing operation H at step 110. At the conclusion of performance of step 120, application 58 would perceive both partitions 62P-1 and 62P-2 to be a single database 62P, such that each application 58 would continue to interact with partitions 62P in the same manner as one partition 62P.
It is contemplated that during the performance of steps 115 and 120, each application 58 will be able to access database 62P in such a manner that, where an application 58 expects to find data on the second database partition 62P-2 as it would expect to find such data at the conclusion of the performance of step 120, then that application 58 will initially look for that data on the second database partition 62P-2, and, where that data is not found, then that application 58 will look for that data on the first database partition 62P-1. An exemplary mechanism for accomplishing this is as follows: Application 58 first attempts to find the data as though the migration to database 62P-2 had already been completed. If the data is not found by application 58 then application 58 would try to find the data again, but instead using the same method that application 58 used before database 62P-2 were added. A more sophisticated mechanism can be made aware of the progress of the data migration to database 62P-2 so that application 58 would know whether a particular piece of data had been migrated, or not.
It will now be understood that method 100 can be used to add any number of partitions (not shown in the Figures) to database partitions 62P-1 and 62P-2, or to database 62B. It should also be understood that hashing operation H can be implemented in a variety of ways. Hashing operation H can be selected from a class of partitioning algorithms that share the unusual property that they substantially maintain a maximum, or substantially maximum, consistency between consecutive partition sizes. An example of one hashing operation H is provided in Appendix I in the form of pseudo-code and referred to as hashing operation H-1.
Table I shows the progression of movement of data as method 100 is performed eight times, each time adding a new partition, using hashing operation H-1, so that at the conclusion database 62P has a total of nine partitions referred to herein as 62P-1, 62P-2, . . . 62P-9. In Table I, the term “Key” refers to the index or other pointer that identifies each portion of the database partition. Thus, each partition in the example of Table I has nineteen portions. It will be understood, however, that in other embodiments each partition can be divided into other portion sizes. The partition number beside each key indicates the location of the portion of data associated with that corresponding Key. Each “*” indicates that the portion corresponding to the * was moved during the previous performance of method 100 by hashing operation H-1.
Another example of a hashing operation H is provided in Appendix 2 and referred to as hashing operation H-2.
Varieties of permutations, combinations, variations and/or subsets of the embodiments discussed herein are contemplated and will now occur to those skilled in the art. For example, system 50 can be varied for environments other than telecommunications, in which case databases 62 that serve applications 58, can in turn service any type of client machine, and not just SCPs 54.
This application is a continuation of U.S. patent application Ser. No. 12/696,414, now U.S. Pat. No. 8,005,804 filed Jan. 29, 2010, which is a continuation of U.S. patent application Ser. No. 11/693,305, filed Mar. 29, 2007 and issued as U.S. Pat. No. 7,680,766 on Mar. 16, 2010. The contents of the above-referenced applications are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5710915 | McElhiney | Jan 1998 | A |
5878409 | Baru et al. | Mar 1999 | A |
6101495 | Tsuchida et al. | Aug 2000 | A |
6405198 | Bitar et al. | Jun 2002 | B1 |
6473774 | Celis et al. | Oct 2002 | B1 |
7680766 | Greer | Mar 2010 | B2 |
8005804 | Greer | Aug 2011 | B2 |
20040199533 | Celis et al. | Oct 2004 | A1 |
20050050050 | Kawamura | Mar 2005 | A1 |
Number | Date | Country | |
---|---|---|---|
20110270811 A1 | Nov 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12696414 | Jan 2010 | US |
Child | 13180866 | US | |
Parent | 11693305 | Mar 2007 | US |
Child | 12696414 | US |