-
Notifications
You must be signed in to change notification settings - Fork 116
Introduction
Rexster is a graph-based web service. Requests are sent to Rexster over HTTP and, in response, Rexster returns JSON formatted results. The sent requests trigger stored traversals that are identified by URIs and are parametrized by the query parameter component of the URI. Rexster can work as a standalone web server or as a servlet through Tomcat. The general system architecture is diagrammed below.
Rexster makes extensive use of Blueprints. Blueprints, amongst other things, is a collection of graph-based interfaces (e.g. graph, vertex, edge, etc.) and implementations (e.g. Neo4j, OpenRDF, etc.). The benefit is that Rexster can be used with various graph backends—-providing ‘plug and play’ support. Two TinkerPop developed packages that make use of Blueprints are Gremlin and Pipes. Gremlin is a general-purpose, graph-based programming language and, in Rexster, serves as a general-purpose interface for working with the graph backend being exposed. On the other hand, Pipes is a data processing framework that has support for Blueprints-based graphs. In general, Gremlin is used for general-purpose queries and Pipes is used for optimized, high-performance specialized graph traversals. In Rexster, the results of both Gremlin and Pipes evaluations are returned to the requester in the form of JSON documents.
While the Gremlin interface to Rexster allows a user to perform any graph-based operation (e.g. add/delete vertices and edges, manipulate the indices of the graph, perform ad-hoc traversals, etc. - see Using Gremlin), Rexster was designed to allow multiple applications in a deployment environment to trigger stored graph traversals and retrieve JSON formatted results. More specifically, Rexster has extended functionality to support score- and rank-based graph traversals.
Rodriguez, M.A., Neubauer, P., The Graph Traversal Pattern, AT&Ti and NeoTechnology Technical Report, April 2010.
Rodriguez, M.A., Allen, D.W., Shinavier, J., Ebersole, G., A Recommender System to Support the Scholarly Communication Process, KRS-2009-02, April 2009.
Rodriguez M.A., Shinavier, J., Exposing Multi-Relational Networks to Single-Relational Network Analysis Algorithms, Journal of Informetrics, volume 4, number 1, pages 29-41, ISSN:1751-1577, Elsevier, doi:10.1016/j.joi.2009.06.004, LA-UR-08-03931, December 2009.