Skip to content

Latest commit

 

History

History
264 lines (189 loc) · 11.1 KB

README.md

File metadata and controls

264 lines (189 loc) · 11.1 KB

adrift

Project for connecting java-based particle transport models to modern web visualisations

Acknowledgments

Acknowledgements

DAFM Logo Marine Institute Logo EU EMFF Logo EU Structural Infrastructure Fund and Programme Logo

This work is supported by the Irish Government and the European Maritime & Fisheries Fund as part of the EMFF Operational Programme for 2014–2020.

Overview

Adrift provides a web frontend for Ichthyop giving a way for less technical users to generate model output and visualisations once the hard work has been done by the oceanographer.

The action is performed by accepting a small number of inputs from the user (location, start time, duration, radius), which are merged into an Ichthyop input xml template at runtime.

The output is available for display in the web browser, and for download as netcdf.

How to Run ADRIFT yourself

Quick Start

  1. git clone this project
git clone https://github.com/irishmarineinstitute/adrift
  1. Download ichthyop zip file into the cloned folder. NB: the current cmems_ibi configuration works only with an older version Ichthyop 3.3_r1037
  2. Build the project. This will take a while the first time.
docker build -t adrift . 
  1. start the docker container
docker run --rm -p 5000:5000 adrift
  1. connect with your browser to http://localhost:5000/

Full configuration

To use ADRIFT with your own models, some further configuration is required before doing the docker build. In particular you will need to modify models.json, and add a template for your Ichtyhop configuration. Both these files are in the webapps folder.

Configuration

Before installation, the models available for production are listed in models.json. Depending on your model type and the source of input data, three modes of operation are available

models.json format

The format for models.json is an object keyed by the model id. Example:

  "cmems_ibi": {
    "id": "cmems_ibi", 
    "name": "cmems_ibi",
    "opendap_url": "http://thredds.marine.ie/thredds/dodsC/IMI_CMEMS/AGGREGATE",
    "nc_fetch_url": "http://thredds.marine.ie/thredds/dodsC/IMI_CMEMS/AGGREGATE?lon[{{lon_range}}],lat[{{lat_range}}],v[{{time_range}}][{{lat_range}}][{{lon_range}}],time[{{time_range}}],u[{{time_range}}][{{lat_range}}][{{lon_range}}]",
    "shrink_domain": true,
    "defaults": {
         "latitude": 45,
         "longitude": -6,
         "northwest_lat": 52,
         "northwest_lon": -4,
         "southeast_lat": 45,
         "southeast_lon": -8,
            "thickness": 2
    },
    "variables": {
     "latitude": "lat",
     "longitude": "lon",
     "time": "time"
    }
  }
id
A short code id for the model; this must be the same as the key used to identify the model (cmems_ibi in the above example). It is used also in the name of the model template file, for example cmems_ibi.xml.mustache
name
The display name for the model; this will appear in the dropdown list on the main page
opendap_url
Required when the model is held in an from opendap server. In the examples provided, the opendap_url is used in both the cmems_ibi and NEATL models.
nc_fetch_url
Required when the model is held in an opendap server, but must be fetched locally using nccopy before processing. The url is in the form of a mustache template containing the placeholders: {{time_range}}, {{lat_range}} and {{lon_range}}
shrink_domain
Whether to provide the user with a box to allow a smaller area to be selected. This is useful to minimise data transfer and processing time where the data is fetched from opendap.
defaults
This section provides default parameters used for display and processing
defaults.latitude
Initial marker placement latitude.
defaults.longitude
Initial marker placement longitude
defaults.northwest_lat
Northwest corner
defaults.northwest_lon
Northwest corner
defaults.southeast_lat
Southeast corner
defaults.southeast_lon
Southeast corner
defaults.thickness
Thickness of the stain (note there is currently no user input for stain thickness)
variables
This section tells ADRIFT how to read the latitude longitude and time from the netcdf files or opendap connection.
variables.latitude
Name of the latitude variable/dimension
variables.longitude
Name of the longitude variable/dimension
variables.time
Name of the time variable/dimension

Mustache templates

For each model listed in models.json, a corresponding Ichthoyp configuration file is required. The Ichthyop file is named with the model id, contains some or all of the placeholders listed below, and has a .mustache extension. For examples see:

File Description
connemara_his.xml.mustache ROMS 3d model with data on local file system
neatl.xml.mustache ROMS 3d model with data in opendap
cmems_ibi.xml.mustache Mercator 2D model with data in opendap

Having added an entry for your model into models.json file, you will create a template from your Ichthyop xml file, into the webapp folder, containing most or all of these placeholders:

{{beginning}}
Use for value of the the initial_time parameter
{{depth}}
Use for value of the depth_stain parameter. Note there is no way for the user to change this value of this parameter at present.
{{duration}}
Use for value of the transport_duration parameter
{{input_path}}
Use for the value of the input_path parameter where the input files are on the local filesystem
{{latitude}}
Use for the value of the lat_stain parameter
{{longitude}}
Use for the value of the lon_stain parameter
{{opendap_url}}
The URL of the opendap aggregate; Use for the value of the opendap_url parameter.
{{output_file_prefix}}
TUse for the value of the file_prefix parameter in the main output section
{{output_path}}
Use for the value of the output_path parameter in the main output section
{{radius}}
Use for the value of the radius_stain parameter
{{release_dir}}
Use for the input_path parameter where the data is fetched from opendap by ADRIFt (see nc_fetch_url above). This is the case for the cmems_ibi example. Note in this case the value of grudu_pattern and gridv_pattern parameters must both be set to input.nc
{{#shrink_domain}}true{{/shrink_domain}}{{^shrink_domain}}false{{/shrink_domain}}
Use for the value of shrink_domain parameter for an opendap model
{{thickness}}
Can be used for the value of the thickness_stain parameter. Note there is no way for the user to change this value of this parameter at present.

installation

Before installing, download ichthyop-3.3.3.zip into the folder.

NB: the current cmems_ibi configuration works only with an older version Ichthyop 3.3_r1037

docker build -t adrift .

Mapping input files

If your project uses files on the local filesystem rather than opendap, you'll need to share them into the docker container such that they are listed in /input/{id} folder, where {id} is the id of your model. This can be done using a docker volume mount.

For example, with the connemara_his project, use a volume mount like this:

docker run -d --restart=always --name=adrift -v /path/to/connemara_his/netcdf/files/:/input/connemara_his -p 5000:5000 adrift

Saving output

To save the output folder, consider using a docker mount. For example:

docker run -d --restart=always --name=adrift -v /path/to/saved/output:/output -p 5000:5000 adrift

Mapping input and output

Below is an example command showing mapping of output folder and one input folder. In this case the application is exposed on port 80.

docker run -d --restart=always \
-v /mnt/prometheus/shared/model/ROMS/OUTPUT/Connemara/FC/WEEK_ARCHIVE/:/input/connemara_his \
-v /home/opsuser/dev/docker-ichthyop/output:/output \
-p 80:5000 --name=adrift adrift

Other notes

The notes below are more specific to installation at Irish Marine Institute, but others may find useful.

nfs mount

Connect ROMS output to the host server.

  1. Install the autofs package if it’s not already installed
  2. put the attached auto.prometheus file in the /etc folder
  3. add the following line to the /etc/auto.master file (which should exist if autofs is installed)
  • /mnt/prometheus /etc/auto.prometheus --ghost --timeout=60 --verbose
  1. create new folder: /mnt/prometheus
  2. restart autofs: /etc/init.d/autofs restart

fetching some model data data files from the main demo server

mkdir -p input/connemara_his
cd input/connemara_his
read username
read password
for item in 18 19 20 21 22 23 24 25; do wget --user=$username --password=$password "https://adrift.demo.marine.ie/nc/CONN_20180406${item}.nc"; done

Running in Docker Swarm

docker build -t 127.0.0.1:5000/adrift .
docker push 127.0.0.1:5000/adrift

Running in docker-compose also check the docs to create the htaccess password file

example docker swarm

docker service create --name adrift --label traefik.port=5000 --label traefik.domain=dm.marine.ie --network traefik-net --mount type=bind,src=/opt/adrift/output,dst=/output --mount type=bind,src=/opt/thredds/connemara_his/,dst=/input/connemara_his --constraint node.hostname=="dmdock04" 127.0.0.1:5000/adrift:latest

Running on server iapetus

cd /home/opsuser/dev/adrift
docker stop adrift && docker rm adrift
docker run -d --name=adrift --restart=always -v /home/DATA/ROMS/OUTPUT/Connemara/FC/WEEK_ARCHIVE/:/input/connemara_his -v /home/DATA/CMEMS:/input/cmems_ibi -v $(pwd)/output:/output -p 80:5000 127.0.0.1:5000/adrift