This document details how to set up the graphical user interface on cartesius and (optionally) connect to it from the (linux) desktop.
- Setting up
${HOME}/.bashrc
:
# .bashrc
# Source global definitions
if [ -f /etc/bashrc ]; then
. /etc/bashrc
fi
# User specific aliases and functions
module load graphviz
if [ -z ${LD_LIBRARY_PATH_ORIG+x} ]; then
export LD_LIBRARY_PATH_ORIG=${LD_LIBRARY_PATH}
fi
export LD_LIBRARY_PATH=${LD_LIBRARY_PATH_ORIG}:${SURFSARA_LIBRARY_PATH}:${HOME}/local/usr/lib
if [ -z ${PKG_CONFIG_PATH_ORIG+x} ]; then
export PKG_CONFIG_PATH_ORIG=${PKG_CONFIG_PATH}
fi
export PKG_CONFIG_PATH=${PKG_CONFIG_PATH_ORIG}:/hpc/sw/graphviz-2.38.0/lib/pkgconfig
export CFLAGS="-I${HOME}/.local/usr/include -I${SARA_INCLUDE_PATH}"
export PATH=${HOME}/tools/cylc/bin:${HOME}/.local/usr/bin:$PATH
- Source
${HOME}/.bashrc
or logout and log back in again. - Install pygraphviz for the graphical graph view:
pip install --global-option=build_ext --global-option="-L/hpc/sw/graphviz-2.38.0/lib" pygraphviz --upgrade --force-reinstall --user
- Download and install a recent CYLC release. Extract the tarball and run make inside the target directory. Note that you may need to press enter a few times for errors building the documentation.
- Create a symlink to the extracted directory so we don't need to update the PATH environment variable everytime we update CYLC (obviously the symlink needs to be changed in that case). To be consistent with the PATH defined in the
${HOME}/.bashrc
file defined at point 1:
mkdir ${HOME}/tools
ln -s ${HOME}/sources/cylc-${VERSION} ${HOME}/tools/cylc
where ${VERSION}
is the version of CYLC installed.
- Setting up CYLC environment variables for running the suites. CYLC does not use the environment defined in
${HOME}/.bashrc
anymore. Loading your modules, defining your variables and sourcing of your python virtual environment is done in${HOME}/.cylc/job-init-env.sh
. Create this file and edit it for your situation. - Define your workflow suite in for example
${HOME}/cylc-suites/${SUITE}
where${SUITE}
is the name of the CYLC suite. - Register CYLC suite. This can be either done from the desktop later or on cartesius using
cycl register
. - You should now be able to run the graphical frontend
gcylc
when logged in on cartesius if you are connected usingssh -X
orssh -Y
.
In order to connect to a CYLC suite on cartesius from your desktop, CYLC needs to be installed there as well. The following steps detail how to do this on a linux desktop.
- Download CYLC and extract. Make sure that the CYLC dependencies are satisfied on your desktop (as this is different for each linux distribution we won't detail it here, please refer to the CYLC documentation). Run make in the extracted directory. Optionally append to the
$PATH
environment variable as discussed above. - If
/usr/bin/env python
links topython3
on your machine, run the following oneliner in the extracted directory:
# change /usr/bin/env python to /usr/bin/env python2 shebang
find ./ -type f | while read in ; do if file -i "${in}" | grep -q x-python ; then sed -i -e 's|/usr/bin/env python|/usr/bin/env python2|g' "${in}" ; fi ; done
- Copy your public ssh key to cartesius
${HOME}/.ssh/authorized_keys
. - Make sure you can login without password using ssh-agent and ssh-add, see for example this link for more details.
- Launch the desktop application for your cartesius user:
${CYLC}/bin/gcylc --use-ssh --user=${USER} --host=cartesius.surfsara.nl --no-login