This is a small guide on how to currently set up openEASE, which will walk you through the steps necessary to install the separate components.
IMPORTANT! The master
-branch does not install the openEASE node-modules separately. If that is necessary for development, check out either the node-modules
-branch (can install and update them via script) or clone the necessary repositories yourself and place them within a node_modules
-directory inside the openease
-repository.
- git
- docker
- docker-compose
Recommended:
- Debian Ubuntu 18.04 LTS or higher as operating system
Note: docker-compose version 1.25.4 is guaranteed to work, if newer versions exhibit problems.
- Set up the Workspace
- Running the App
- Workspace Update-Script
- Useful stuff
- Possible Errors, Troubleshooting, etc.
-
Setting up your system: We recommend running
openEASE
on Debian Ubuntu 18.04 or higher for the best experience. But it should be possible to run it on other operating systems as well. Furthermore, make sure to havegit
,docker
, anddocker-compose
installed as well. -
Cloning the necessary repositories: There are two ways to clone the necessary repositories, which is either to do it manually, or by using our install-script.
2.1. Using the install-script
First, clone this repository or save the install-script
install.sh
together with the configurationconfig.sh
in the same directory somewhere on your system. Cloning the repository has the benefit that you also save the update-scriptupdate.sh
into the same directory already, meaning you can later execute it without further setup.By default, the script would install
openEase
into~/Documents/openease_workspace
. However, if you want to change the installation location, then open the script with an editor of your choice, and edit the following path:OPENEASE_ROOT_DIR=<path to the parent directory of the repositories>
Normally, the script would clone the
openease
,knowrob
anddockerbridge
repositories into the same parent directory, but if you instead want them to end up in different locations, then change the following paths:OPENEASE_PARENT_DIR=<path to the openease repository> [...] KNOWROB_PARENT_DIR=<path to the knowrob repository> [...] DOCKERBRIDGE_PARENT_DIR=<path to the openease-dockerbridge repository>
If you want to change the folder names the modules will be installed into, you can adjust the following variables:
# folder names for the modules [...] OPENEASE="openease" # openease webapp-container KNOWROB="knowrob" # knowrob-container DOCKERBRIDGE="dockerbridge" # dockerbridge-container
It is also possible to change the target repositories, if, for example, you want to clone a fork, instead of the original repository. For that you can replace any of the following with the HTTPS to your git-fork:
OPENEASE_REPO="https://github.com/ease-crc/openease.git" KNOWROB_REPO="https://github.com/daniel86/knowrob.git" DOCKERBRIDGE_REPO="https://github.com/ease-crc/openease_dockerbridge.git"
Finally, open a terminal and execute
bash <location of the script>/install.sh
. Check the console output and folder structures to see if everything installed properly. The intended folder structure (for the default installation) should be:<workspace directory> └─ openease └─ knowrob └─ openease-dockerbridge
2.2. Cloning everything manually
Create a workspace folder somewhere and clone the following three repositories into it:
openease
: https://github.com/ease-crc/openeaseknowrob
: https://github.com/daniel86/knowrobopenease-dockerbridge
: https://github.com/ease-crc/openease_dockerbridge
The directory structure should then look something like this:
<workspace directory> └─ openease └─ knowrob └─ openease-dockerbridge
(It is of course also possible to put them in separate places, but this guide will assume they share the same parent directory.)
-
Building the Docker Containers: Open a terminal and follow the steps.
-
openease
container: Change to<parent dir>/openease
and rundocker build -t openease/app .
-
knowrob
container: First, with an editor of your choice, open thedockerfile
in<parent dir>/knowrob/docker
, and change line 85 to:git clone https://github.com/daniel86/knowrob.git && \
Then, in your terminal change to
<parent dir>/knowrob/docker
and rundocker build -t openease/knowrob .
-
openease-dockerbridge
container: Change to<parent dir>/openease-dockerbridge
and rundocker build -t openease/dockerbridge .
Note: If you have an Apple Silicon processor, it is strongly recommended to add the
--platform linux/amd64
flag as well. This runs slower and consumes more memory than a native build, but it would likely fail otherwise, at least according to our testing. This might become obselete in future, but at least as of now we recommend it.Alternatively, it is possible to build the containers with the update-script by passing the
-b
flag (s. Workspace Update-Script). Make sure to follow the given steps, before executing the script. The script automatically detects if you have an Apple Silicon processor and passes the--platform linux/amd64
flag to the build if necessary.Note: The
openease
andknowrob
container will take some time to finish building. If you have a multi-core processor, you can run the three builds in different terminals to save some time. -
After everything is set up and you have built all the necessary containers from our repositories, open a terminal and change to the directory of your openease
repository. Then run docker-compose up
. If everything runs smoothly, you can access the app via localhost:5000
in your webbrowser.
Running docker-compose down
in a separate terminal will shut down the application. Alternatively press CTRL
+ C
and then you can run the command in the same terminal.
To use the app, you will need to create an account or alternatively request the admin login from your supervisor(s). In order to access the Neem-Hub, one needs to enter the access credentials in the NEEM-Hub settings. Please request Neem configurations from your supervisor(s) or researchers at IAI-Bremen.
We provide an update script, so users do not need to manually update all the parts of the software. The script can update all the repositories which we cloned and build all the containers from the previous chapter. To use the script, do the following:
-
If you have already cloned this repository according to point 2.1 in the section Set up the Workspace, then you can skip to point 2. Otherwise, save the update-script together with the configuration
config.sh
in the same directory somewhere on your system. -
If you used the install script and already set up your workspace according to point 2.1 in the section Set up the Workspace, then you are good to go and can skip to point 3. If instead, you cloned the repositories manually, open
config.sh
with an editor of your choice, and edit the paths to the repositories.First, if
openease
,knowrob
, anddockerbridge
all have the same parent directory, only change the following variable:OPENEASE_ROOT_DIR=<path to the parent directory of the repositories>
Otherwise change the following paths:
OPENEASE_PARENT_DIR=<path to the openease repository> [...] KNOWROB_PARENT_DIR=<path to the knowrob repository> [...] DOCKERBRIDGE_PARENT_DIR=<path to the openease-dockerbridge repository>
It might also be useful to check the variables for the folder names, to check if they are the same as your local folder names:
# folder names for the modules [...] OPENEASE="openease" # openease webapp-container KNOWROB="knowrob" # knowrob-container DOCKERBRIDGE="dockerbridge" # dockerbridge-container
-
You can run the script with
bash <location of the script>/update.sh
together with any of the following option flags:-h: will display help information -u: will update all the repositories -b: will build all the containers
Note: The script automatically detects if you have an Apple Silicon processor and passes the --platform linux/amd64
flag to the build if necessary.
A few remarks on how the script works:
- If executed without any option flags, the script will try to update the repositories and then build the containers. This is equivalent to running the script with both the
-u
and-b
flags, except that the user will be prompted to confirm the actions. - The order of the flags generally doesn't matter, i.e., if the update and build flag are passed together, then the update is always executed before the build.
- If
-h
is used with other flags, it will take priority and disable the other flags' functionalities.
You can add these utility functions to your .bashrc
, to have access to them from anywhere.
function docker-remove-with-images() {
docker rm $(docker ps -a -q)
docker rmi $(docker images -q)
}
function docker-stop-and-remove() {
docker kill $(docker ps -q)
docker rm $(docker ps -a -q)
docker kill $(docker ps -a -q)
}
export -f docker-remove-with-images
export -f docker-stop-and-remove
You can open .bashrc
with, for example, nano <path to .bashrc-file>/.bashrc
. Go to the end of the file and add the code snippet from above. Then enter the exit command (usually CTRL
+ X
) and confirm to save the changes to the same file. Lastly either log out and back in, or just type the following command source <path to .bashrc-file>/.bashrc
.
You can then type the following commands into your terminal:
docker-remove-with-images
: removes all docker containers and imagesdocker-stop-and-remove
: stops all containers and removes all the containers
If you see something like this:
postgres | ERROR: column ... does not exist at character ...
then you might need to remove your volumes. Execute the following three commands in your terminal:
docker-compose down
docker-stop-and-remove (all containers)
docker volume rm $(docker volume ls -q)
WARNING: The third command removes all volumes, even from other projects. If you need to preserve those, then you can instead use either docker volume prune
(removes only volumes not used by any container), or list your volumes with docker volume ls
and use docker volume rm <VOLUME NAME>
.
To set up the https cert, in your terminal execute the following two commands:
cd <YOUR WORKSPACE>/openease/certs/
./gencert.sh
You can also see the docs.
When calling the install or update script from within another script, it might be possible, that the path to config.sh
cannot be properly resolved. This might result in more errors. The fix is to replace the relative path to the config file at the beginning of both scripts with an absolute one. There change this:
source ./config.sh
to
source <absolute path to config-file>/config.sh