GeoMesa is an open-source, distributed, spatio-temporal database built on top of the Apache Accumulo column family store. GeoMesa implements standard Geotools interfaces to provide geospatial functionality over very large data sets to application developers. GeoMesa provides plugins for exposing geospatial data stored in Accumulo via standards-based OGC HTTP services and cluster monitoring and management tools within the GeoServer administrative interface.
GeoMesa is a member of the LocationTech working group of the Eclipse Foundation.
Latest release: 1.1.0-rc.7
Development version (source only): 1.2.0-SNAPSHOT
1.0.x release: geomesa-accumulo1.5-1.0.0-rc.7
NOTE: The current recommended version is 1.1.0-rc.7
. The most recent tar.gz assembly can be
downloaded here which contains the Accumulo distributed runtime jar, Accumulo GeoServer plugin, and command line tools.
GeoMesa artifacts can be downloaded from the LocationTech Maven repository
Snapshots are available in the LocationTech Snapshots Repository
To upgrade between minor releases of GeoMesa, the versions of all GeoMesa components must match.
This means that the version of the geomesa-accumulo-distributed-runtime
JAR installed on Accumulo tablet servers must match the version of the geomesa-accumulo-gs-plugin
JAR installed in the WEB-INF/lib directory of GeoServer.
Requirements:
- Java JDK 7
- Apache Maven 3.2.2 or later
- git
- Accumulo version 1.5.x or 1.6.x and/or Kafka version 0.8.2.x.
Navigate to where you would like to download this project.
git clone git@github.com:locationtech/geomesa.git
cd geomesa
The project is managed by Maven. The version of Accumulo supported is controlled by the accumulo-1.5
property; to target Accumulo 1.5:
mvn clean install -Daccumulo-1.5
If the property is omitted, support for Accumulo 1.6 is assumed:
mvn clean install
The build/mvn
script is a wrapper around Maven that builds the project using the Zinc incremental compiler:
build/mvn clean install -Daccumulo-1.5 # Accumulo 1.5
build/mvn clean install # Accumulo 1.6
From the root directory, the commands above will build JARs for each sub-project with its additional dependencies bundled.
- Quick Start on the main documentation site.
- FAQ
- Tutorials
- GeoMesa Users and Dev mailing list archives
- READMEs are provided under most modules: Tools, Jobs, etc
- geomesa-accumulo: the implementations of the core Accumulo indexing structures, Accumulo iterators, and the GeoTools interfaces for exposing the functionality as a
DataStore
to both application developers and GeoServer. Assembles a jar with dependencies that must be distributed to Accumulo tablet servers lib/ext directory or to an HDFS directory where Accumulo's VFSClassLoader can pick it up. - geomesa-assemble: packages the GeoMesa distributed runtime, GeoMesa GeoServer plugin, and GeoMesa Tools. You can manually assemble using the
assemble.sh
script contained in the module. - geomesa-compute: utilities for working with distributed computing environments. Currently, there are methods for instantiating an Apache Spark Resilient Distributed Dataset from a CQL query against data stored in GeoMesa. Eventually, this project will contain bindings for traditional map-reduce processing, Scalding, and other environments.
- geomesa-convert: a configurable and extensible library for converting data into SimpleFeatures.
- geomesa-examples: includes Developer quickstart tutorials and examples for how to work with GeoMesa in Accumulo and Kafka.
- geomesa-features: includes code for serializing SimpleFeatures and custom SimpleFeature implementations designed for GeoMesa.
- geomesa-filter: a library for manipulating and working with GeoTools Filters.
- geomesa-gs-plugin: packages plugins which provide WFS and WMS support for various
DataStore
types including accumulo, bigtable, kafka, and stream DataStores. These are packaged as zip files and can be deployed in GeoServer by extracting their contents into geoserver/WEB-INF/lib/ - geomesa-hbase: an implementation of GeoMesa on HBase and Google Cloud Bigtable.
- geomesa-jobs: map/reduce and scalding jobs for maintaining GeoMesa.
- geomesa-kafka: an implementation of GeoMesa in Kafka for maintaining near-real-time caches of streaming data.
- geomesa-process: analytic processes optimized on GeoMesa data stores.
- geomesa-raster: adds support for ingesting and working with geospatially-referenced raster data in GeoMesa.
- geomesa-security: adds support for managing security and authorization levels for data stored in GeoMesa.
- geomesa-stream: a GeoMesa library that provides tools to process streams of
SimpleFeatures
. - geomesa-tools: a set of command line tools for managing features, ingesting and exporting data, configuring tables, and explaining queries in GeoMesa.
- geomesa-utils: stores our GeoHash implementation and other general library functions unrelated to Accumulo. This sub-project contains any helper tools for geomesa. Some of these tools such as the GeneralShapefileIngest have Map/Reduce components, so the geomesa-utils JAR lives on HDFS.
- geomesa-web: web services for accessing GeoMesa.
- geomesa-z3: the implementation of Z3, GeoMesa's space-filling Z-order curve.
To test and interact with core functionality, the Scala console can be invoked in a couple of ways. From the root directory by specifying geomesa-accumulo-datastore
cd geomesa-accumulo
mvn -pl geomesa-accumulo-datastore scala:console
By default, all of the project packages in geomesa-accumulo-datastore
are loaded along with JavaConversions, JavaConverters.