The Render Web Services module provides level 2 REST APIs to persisted collections of tile and transform specifications (see data model). The Render Web Services API documentation identifies the specific supported APIs.
The Render Web Services module is packaged as a Java web application archive (war file) deployed on a Jetty web server/container. It connects to a MongoDB database where tile and transform specifications are persisted (see data model).
The web server and database components can be run on the same machine for small scale processing or evaluation purposes. For large scale processing needs, each component should be deployed on separate machines that are tuned for their specific purpose.
These installation instructions cover setup of an evaluation instance with a collocated web server and database running on Ubuntu 16.04.
Note: In lieu of running these steps manually, you may prefer to use a Docker deployment instead. Finally, if you'd like to run this exact installation process along with the Render Web Services Example in Docker, you can use this Dockerfile.
sudo apt-get install -y git maven
git clone https://github.com/saalfeldlab/render.git
# assumes cloned render repository is in ./render
cd ./render
./render-ws/src/main/scripts/install.sh
# assumes current directory is still the cloned render repository root (./render)
export JAVA_HOME=`readlink -m ./deploy/jdk*`
mvn package
# assumes current directory is still the cloned render repository root (./render)
cp render-ws/target/render-ws-*.war deploy/jetty_base/webapps/render-ws.war
These instructions were taken from https://docs.mongodb.com/v4.0/tutorial/install-mongodb-on-ubuntu/
# needed for access to https mongodb resources
RUN apt-get install apt-transport-https
# steps from https://docs.mongodb.com/v4.0/tutorial/install-mongodb-on-ubuntu/
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 9DA31620334BD75D9DCB49F368818C72E52529D4
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/4.0 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.0.list
sudo apt-get update
# NOTE: This step is not documented on the MongoDB web site, but for some reason is required to avoid "mongod: unrecognized service" errors later
# See https://github.com/Microsoft/WSL/issues/1822 for details
sudo apt-get install -y mongodb
sudo apt-get install -y mongodb-org=4.0.6 mongodb-org-server=4.0.6 mongodb-org-shell=4.0.6 mongodb-org-mongos=4.0.6 mongodb-org-tools=4.0.6
echo "mongodb-org hold" | sudo dpkg --set-selections
echo "mongodb-org-server hold" | sudo dpkg --set-selections
echo "mongodb-org-shell hold" | sudo dpkg --set-selections
echo "mongodb-org-mongos hold" | sudo dpkg --set-selections
echo "mongodb-org-tools hold" | sudo dpkg --set-selections
# Create systemd service file
# NOTE: This file has to be named mongodb.service (instead of mongod.service) for some reason
sudo curl -o /lib/systemd/system/mongodb.service "https://raw.githubusercontent.com/mongodb/mongo/v4.0/rpm/mongod.service"
# NOTE: The service has to be mongodb (instead of mongod) for some reason.
sudo service mongodb start
# assumes current directory is still the cloned render repository root (./render)
deploy/jetty_base/jetty_wrapper.sh start
The Render Web Services Example workflow steps demonstrate how this installation can be used for a small example project.