MrGeo Geoserver Plugin is an open source software data plugin for the GeoServer package. It allows Geoserver to communicate directly with MrGeo data sources
MrGeo Geoserver Plugin licensed under the GPL v2.0.
This plugin is intended to be used as part of an existing GeoServer instance. Setting up GeoServer is out of the scope of this document.
MrGeo Geoserve Plugin uses Apache Maven for a build system.
% mvn clean package
Here are the version variables that may need to be set according to your particular build situation. They can be set by adding -D<variable>=<value>
to the maven build line.
Variable | Default Value | Notes |
---|---|---|
final.classifier | cdh5.6.0 | Classifier for the final jar/tar files produced |
commons-codec.version | 1.9 | |
mrgeo.version | 1.1.0-${final.classifier}-SNAPSHOT | |
geoserver.version | 2.8.1 | |
geotools.version | 14.0 | |
hadoop.yarn.version | 2.6.0-cdh5.6.0 | |
httpclient.version | 4.5 | |
jai.core.version | 1.1.3 | |
jai.imageio.version | 1.1 | |
slf4j.version | 1.7.5 | |
java.version | 1.7 |
- Make sure these environment variables are available to the web container you are running. For Tomcat, add them to TOMCAT_HOME/bin/setenv.sh. Note: The environment variables should also be available on the classpath as well.
- Variables
MRGEO_COMMON_HOME=/usr/local/mrgeo
MRGEO_CONF_DIR=/usr/local/mrgeo/conf
HADOOP_CONF_DIR=/usr/local/hadoop/conf
- For Tomcat, add these to TOMCAT_HOME/bin/setenv.sh.
export MRGEO_COMMON_HOME=/usr/local/mrgeo
export MRGEO_CONF_DIR=/usr/local/mrgeo/conf
export HADOOP_CONF_DIR=/usr/local/hadoop/conf
export CLASSPATH=\$MRGEO_COMMON_HOME:\$MRGEO_CONF_DIR:\$HADOOP_CONF_DIR
export CATALINA_OPTS="-DMRGEO_COMMON_HOME=/usr/local/mrgeo " \
"-DMRGEO_CONF_DIR=/usr/local/hadoop/conf " \
"-DHADOOP_CONF_DIR=/usr/local/hadoop " \
"-DGEOSERVER_DATA_DIR=/mnt/geoserver-data " \
"-DGEOWEBCACHE_CACHE_DIR=/mnt/geoserver-cache " \
"-Xms512m -Xmx12G " \
"-XX:NewSize=256m -XX:MaxNewSize=256m " \
"-XX:PermSize=256m -XX:MaxPermSize=256m -XX:+DisableExplicitGC"
-
Take the gt-mrgeo-1.0--SNAPSHOT.tar.gz file built previously, and unpack it into the geoserver WEB-INF/lib directory. Care has been taken to exclude any duplicate, but version different, jars used between MrGeo and GeoServer. However, changes in the various versions of both may have allowed dupliclates to slip in. The first time unpacking, you may want to make sure none exist.
-
Copy a mrgeo.config into the geoserver data directory. If you wish to use defaults for all the config options, an empty file can be created.
-
Copy mrgeo.conf to the MRGEO_CONF_DIR directory (e.g. /usr/local/mrgeo/conf)
- Modify mrgeo.conf to point to the correct data location
image.base = /mrgeo/images
vector.base = /mrgeo/vectors
kml.base = /mrgeo/kml
tsv.base = /mrgeo/tsv
colorscale.base = /mrgeo/color-scales
If you are using AWS S3 for data storage, you can use the addresses here as well. i.e. s3://mrgeo/images
- Copy hadoop configurations to HADOOP_CONF_DIR (e.g. /usr/local/hadoop/conf). While any version of Hadoop's configuration files should be OK, it is probably best to use the same version as used to build MrGeo.
- Files needed are:
core-site.xml
,hadoop-env.sh
,hdfs-site.xml
,jets3t.properties
,mapred-site.xml
, andyarn-site.xml
. If you are using S3 for data storage, you can start with the default files and add the changes noted below - If using S3 for data storage, add the S3 key/secret key to Hadoop's
core-site.xml
<property>
<name>fs.s3.awsAccessKeyId</name>
<value><key</value>
</property>
<property>
<name>fs.s3.awsSecretAccessKey</name>
<value><secret key></value>
</property>
<property>
<name>fs.s3n.awsAccessKeyId</name>
<value><key></value>
</property>
<property>
<name>fs.s3n.awsSecretAccessKey</name>
<value><secret key></value>
</property>
- That should be it, restart the web container and MrGeo should be integrated with GeoServer
The mrgeo.config file is used to supply the MrGeo Plugin with configuration options. This is a standard Java-style properties file, so values are in = format.
NOTE: For now, the mrgeo plugin automaticly checks and updates the MrGeo Layers ONCE at startup, no matter what the config options say. This behaviour may change in the future.
Name | Default | Description |
---|---|---|
enable.update | false | Enable periodic updates to the layers. If true, the plugin will periodically check MrGeo and add or remove layers as needed |
update.time | 300 | Seconds to periodically check MrGeo for updated layers |
workspace | mrgeo | Workspace name for MrGeo layers |
coveragestore | mrgeo | Coverage (store) name for the MrGeo layers |
namespace | workspace | Namespace name for the MrGeo layers |
user.name | none | User name for accessing MrGeo layers (This is normally not set, as there are no user names/roles set on layers) |
user.roles | none | User roles for accessing MrGeo layers (This is normally not set, as there are no user names/roles set on layers) |
All pull request contributions to this project will be released under the GPL 2.0 license.
TBD