| Resolver Database ClassThe resolver database class is highly configurable, allowing you to optimally set up Kowari for the appropriate usage requirements. By inserting different classes into the constructor of the database class you can set it up as a: 
 There are five configurable parts for the database with respect to its operation: 
 The Persistent String and Node Pools maintain the mappings of node id to string representations for all current models in both the System and External models. The Temporary Node and Temporary String Pools are used for storing temporary nodes during a query. To ensure proper functionality, the System Resolver Factory determines which resolver manages the system model information. It is recommended that you use internal resolvers for the System Resolver Factory because of their stability, but external resolvers can also be used. By default, Persistent Node and Persistent String Pools use disk based storage, while Temporary Node and Temporary String Pools use memory based storage. Node PoolsNode and String Pools work closely together to manage the data contained in the system model. Most importantly, the Node Pool, which contains the numerical representations of nodes within the graph structure of the models which the String Pool depends upon. Each node in a model's graph is assigned a unique numerical representation that is stored and handled within the Node Pool. All nodes are local to the system model, that is they only have scope within the system model and are meaningless in any other server. String PoolsWorking as a compliment to the Node Pool, the String Pool maps node numbers to their string counterparts, or actual values. Since all strings are globally available (that is, they hold the same meaning wherever they are used), localization is required before the node's value can be retrieved. Temporary PoolsTemporary Pools are a combination of a Node and a String pool that maintains nodes used during queries that are not part of the store. When a query is executed, the Persistent Pools are consulted and if the node cannot be found, the Temporary Pool creates a new entry. This prevents the creation of nodes in the store which are not part of the graph. Temporary nodes are given IDs that do not overlap with the existing store node IDs and are consulted before the Persistent Pools. After a query is executed, all temporary nodes are deleted. Persistent PoolsAll data store graph nodes are stored in the Persistent Pools, allowing quick and easy processing of queries. Unlike Temporary Pools, they are permanent and remain after the query is executed. Generally, only the nodes handled by models in the internal resolvers are stored in the Persistent Pools, with the external resolvers' nodes being handled by the resolver itself. System Resolver FactoryThe System Resolver Factory is a title rather than an actual functioning part of any database instance. It defines the resolver factory used to create a resolver that manages the system model. When deciding on which resolver to use, it is important to note that the resolver is in charge of addition, removal and modification of the models and should allow for this functionality. The other factor to consider is that the resolver's store should reflect the usage of Kowari. That is, for a persistent system model, use a persistent resolver, and for a temporary system model, use a temporary resolver. Internal ResolversAn Internal Resolver operates on a data store internal to a Kowari server and therefore has its own model within the system model. Usually, internal resolvers are used alongside data stores with RDF ready information, which requires very little or no conversion. It is possible however, to set up an internal relational database resolver or similar. Internally resolved models are the most stable as they are Kowari controlled. The data is guaranteed at all times as is always accessible for the life of the server. Internal resolvers use the Persistent Node and String Pools and therefore require no translation of the nodes in the data store's graphs. External ResolversAn External Resolver has its model outside of the scope of the system model and outside the control of Kowari. External resolvers are useful for data stores that are not in an RDF ready format and require some processing before results can be returned. This is most often used for resolving files of various formats, but can also be useful for connecting to a relational database and converting results to RDF on the fly, or reading from an unknown source's stream. There is a danger to using external resolvers because the data being queried is not controlled by Kowari and there is no guarantee of the model being present. External factors, such as other users, servers, or security protocols may alter or remove files or stores being resolved, thus contaminating or causing errors in the results. Since external resolvers operate outside the scope of the Kowari server, they are responsible for managing their own Node and String Pools as well as translating them across to the Kowari pools during a query. This also applies to blank nodes, whose values should be maintained across resolutions for the same file otherwise the results might become unpredictable. Once a query's model is determined to be external to the system model, the protocol is checked to determine how the resolver should connect to the resource. After setting up a connection, the actual URL's type is determined and the appropriate resolver is selected to resolve the constraints. | Latest NewsKowari 1.1.0 Pre-release 1 Released     | |||||
| © 2001-2004 Tucana Technologies, Inc. Some rights reserved. |