Persistent key-value repository with a pluggable architecture to abstract physical storage
0 Assignments
0 Petitions
Accused Products
Abstract
A system and techniques are described for managing key-value pairs using an architecture that does not restrict its users to any specific platform or storage subsystem. According to one aspect of the invention, the repository is portable in that the architecture need not change based on the environment and platform in which the repository is used. Rather, the portion of the architecture that is platform-specific is limited to plug-ins at a storage abstraction layer of the repository. The plug-ins expose the same storage abstraction interface to the other layers of the repository, but are implemented to interact with different platforms and storage subsystems. Consequently, in response to being ported from one platform to another, the repository may simply change the plug-in to invoke for persistent storage operations.
-
Citations
34 Claims
-
1-8. -8. (canceled)
-
9. A method for storing key-value pairs, the method comprising:
-
exposing a repository interface through which clients may make calls to store and access key-value pair information in a repository;
receiving a call from a client through a routine that implements a portion of said repository interface; and
based on said call, determining whether to establish a component of said repository that is associated with said client as a caching component responsible for managing a cache for said repository. - View Dependent Claims (10, 11, 12, 13, 14)
-
-
15. A method for storing key-value pairs, the method comprising:
-
exposing a repository interface through which clients may make calls to store and access key-value pair information in a repository designed specifically for key-value pair information;
receiving one or more calls from a client through said repository interface;
wherein said one or more calls are received at said repository interface prior to allocating, on persistent storage, any structures for said repository for persistently storing said key-value pair information; and
based on said one or more calls, creating structures for persistently storing said key-value pair information on said persistent storage. - View Dependent Claims (16, 17)
-
-
18-25. -25. (canceled)
-
26. A computer-readable medium carrying instructions for storing key-value pairs, the computer-readable medium comprising instructions for performing the steps of:
-
exposing a repository interface through which clients may make calls to store and access key-value pair information in a repository;
receiving a call from a client through a routine that implements a portion of said repository interface; and
based on said call, determining whether to establish a component of said repository that is associated with said client as a caching component responsible for managing a cache for said repository. - View Dependent Claims (27, 28, 29, 30, 31)
-
-
32. A computer-readable medium carrying instructions for storing key-value pairs, the computer-readable medium comprising instructions for performing the steps of:
-
exposing a repository interface through which clients may make calls to store and access key-value pair information in a repository designed specifically for key-value pair information;
receiving one or more calls from a client through said repository interface;
wherein said one or more calls are received at said repository interface prior to allocating, on persistent storage, any structures for said repository for persistently storing said key-value pair information; and
based on said one or more calls, creating structures for persistently storing said key-value pair information on said persistent storage. - View Dependent Claims (33, 34)
-
Specification