From 0430934118227891e27e2096d4243a324d696f7e Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Luk=C3=A1=C5=A1=20Krup=C4=8D=C3=ADk?= <lukas.krupcik@vsb.cz>
Date: Fri, 7 Jul 2017 13:25:32 +0200
Subject: [PATCH] add spack

---
 docs.it4i/software/spack.md | 355 ++++++++++++++++++++++++++++++++++++
 mkdocs.yml                  |   1 +
 2 files changed, 356 insertions(+)
 create mode 100644 docs.it4i/software/spack.md

diff --git a/docs.it4i/software/spack.md b/docs.it4i/software/spack.md
new file mode 100644
index 000000000..4ef2bb55a
--- /dev/null
+++ b/docs.it4i/software/spack.md
@@ -0,0 +1,355 @@
+# Spack
+
+Spack is a package manager for supercomputers, Linux, and macOS. It makes installing scientific software easy. With Spack, you can build a package with multiple versions, configurations, platforms, and compilers, and all of these builds can coexist on the same machine.
+
+Homepage: [https://spack.io/](https://spack.io/)
+Documentation: [https://spack.readthedocs.io/en/latest/](https://spack.readthedocs.io/en/latest/)
+
+## Spack On IT4Innovations Clusters
+
+```console
+
+~]$ ml av Spack
+
+---------------------- /apps/modules/devel ------------------------------
+   Spack/default
+
+```
+
+! note
+  Spack/default is rule for setting up local installation
+
+
+## First Usage Module Spack/default
+
+The Spack will be installed into your /home, create folder Spack for installing software and set the configuration into ~/.spack/configure.yml
+
+```console
+~]$ ml Spack
+== Settings for first use
+Couldn't import dot_parser, loading of dot files will not be possible.
+== temporary log file in case of crash /tmp/eb-wLh1RT/easybuild-54vEn3.log
+== processing EasyBuild easyconfig /apps/easybuild/easyconfigs-it4i/s/Spack/Spack-0.10.0.eb
+== building and installing Spack/0.10.0...
+== fetching files...
+== creating build dir, resetting environment...
+== unpacking...
+== patching...
+== preparing...
+== configuring...
+== building...
+== testing...
+== installing...
+== taking care of extensions...
+== postprocessing...
+== sanity checking...
+== cleaning up...
+== creating module...
+== permissions...
+== packaging...
+== COMPLETED: Installation ended successfully
+== Results of the build can be found in the log file(s) ~/.local/easybuild/software/Spack/0.10.0/easybuild/easybuild-Spack-0.10.0-20170707.122650.log
+== Build succeeded for 1 out of 1
+== Temporary log file(s) /tmp/eb-wLh1RT/easybuild-54vEn3.log* have been removed.
+== Temporary directory /tmp/eb-wLh1RT has been removed.
+== Create folder ~/Spack
+
+The following have been reloaded with a version change:
+  1) Spack/default => Spack/0.10.0
+
+~]$ spack --version
+0.10.0
+```
+
+## Usage Module Spack/default
+
+```console
+~]$ ml Spack
+
+The following have been reloaded with a version change:
+  1) Spack/default => Spack/0.10.0
+
+~]$ spack --version
+0.10.0
+```
+
+## Build Software Package
+
+### Search For Available Software
+
+To install software with Spack, you need to know what software is available. Using the `spack list` command.
+
+```console
+~]$ spack list
+==> 1114 packages.
+abinit                    font-bh-100dpi                   libffi             npm                                    py-ply                     r-maptools       tetgen
+ack                       font-bh-75dpi                    libfontenc         numdiff                                py-pmw                     r-markdown       tethex
+activeharmony             font-bh-lucidatypewriter-100dpi  libfs              nwchem                                 py-prettytable             r-mass           texinfo
+adept-utils               font-bh-lucidatypewriter-75dpi   libgcrypt          ocaml                                  py-proj                    r-matrix         texlive
+adios                     font-bh-ttf                      libgd              oce                                    py-prompt-toolkit          r-matrixmodels   the-platinum-searcher
+adol-c                    font-bh-type1                    libgpg-error       oclock                                 py-protobuf                r-memoise        the-silver-searcher
+allinea-forge             font-bitstream-100dpi            libgtextutils      octave                                 py-psutil                  r-mgcv           thrift
+allinea-reports           font-bitstream-75dpi             libhio             octave-splines                         py-ptyprocess              r-mime           tinyxml
+ant                       font-bitstream-speedo            libice             octopus                                py-pudb                    r-minqa          tinyxml2
+antlr                     font-bitstream-type1             libiconv           ompss                                  py-py                      r-multcomp       tk
+ape                       font-cronyx-cyrillic             libint             ompt-openmp                            py-py2cairo                r-munsell        tmux
+apex                      font-cursor-misc                 libjpeg-turbo      opari2                                 py-py2neo                  r-mvtnorm        tmuxinator
+applewmproto              font-daewoo-misc                 libjson-c          openblas                               py-pychecker               r-ncdf4          transset
+appres                    font-dec-misc                    liblbxutil         opencoarrays                           py-pycodestyle             r-networkd3      trapproto
+apr                       font-ibm-type1                   libmesh            opencv                                 py-pycparser               r-nlme           tree
+...
+```
+
+#### Specify Software Version (for package)
+
+To see more available versions of a package, run `spack versions`.
+
+```console
+~]$ spack versions git
+==> Safe versions (already checksummed):
+  2.11.0  2.9.3  2.9.2  2.9.1  2.9.0  2.8.4  2.8.3  2.8.2  2.8.1  2.8.0  2.7.3  2.7.1
+==> Remote versions (not yet checksummed):
+  Found no versions for git
+```
+
+## Graph For Software Package
+
+Spack provides the `spack graph` command for graphing dependencies. The command by default generates an ASCII rendering of a spec’s dependency graph.
+
+```console
+~]$ spack graph git
+o  git
+|\
+| |\
+| | |\
+| | | |\
+| | | | |\
+| | | | | |\
+| | | | | | |\
+| | | | | | | |\
+| | | | | | | o |  curl
+| |_|_|_|_|_|/| | 
+|/| | | |_|_|/ /
+| | | |/| | | | 
+| | | o | | | |  openssl
+| |_|/ / / / /
+|/| | | | | | 
+| | | | o | |  gettext
+| | | | |\ \ \
+| | | | | |\ \ \
+| | | | | | |\ \ \
+| | | | | | | |\ \ \
+| | | | | | | o | | |  libxml2
+| |_|_|_|_|_|/| | | | 
+|/| | | | |_|/| | | | 
+| | | | |/| | | | | | 
+o | | | | | | | | | |  zlib
+ / / / / / / / / / /
+| | | o | | | | | |  xz
+| | |  / / / / / /
+| | | o | | | | |  tar
+| | |  / / / / /
+| | | | o | | |  pkg-config
+| | | |  / / /
+o | | | | | |  perl
+ / / / / / /
+o | | | | |  pcre
+ / / / / /
+| o | | |  ncurses
+|  / / /
+| | | o  autoconf
+| | | o  m4
+| | | o  libsigsegv
+| | | 
+o | |  libiconv
+ / /
+| o  expat
+| 
+o  bzip2
+```
+
+### Information For Software Package
+
+To get more information on a particular package from `spack list`, use `spack info`.
+
+```console
+~]$ spack info git
+Package:    git
+Homepage:   http://git-scm.com
+
+Safe versions:  
+    2.11.0    https://github.com/git/git/tarball/v2.11.0
+    2.9.3     https://github.com/git/git/tarball/v2.9.3
+    2.9.2     https://github.com/git/git/tarball/v2.9.2
+    2.9.1     https://github.com/git/git/tarball/v2.9.1
+    2.9.0     https://github.com/git/git/tarball/v2.9.0
+    2.8.4     https://github.com/git/git/tarball/v2.8.4
+    2.8.3     https://github.com/git/git/tarball/v2.8.3
+    2.8.2     https://github.com/git/git/tarball/v2.8.2
+    2.8.1     https://github.com/git/git/tarball/v2.8.1
+    2.8.0     https://github.com/git/git/tarball/v2.8.0
+    2.7.3     https://github.com/git/git/tarball/v2.7.3
+    2.7.1     https://github.com/git/git/tarball/v2.7.1
+
+Variants:
+    None
+
+Installation Phases:
+    install
+
+Build Dependencies:
+    autoconf  curl  expat  gettext  libiconv  openssl  pcre  perl  zlib
+
+Link Dependencies:
+    curl  expat  gettext  libiconv  openssl  pcre  perl  zlib
+
+Run Dependencies:
+    None
+
+Virtual Packages: 
+    None
+
+Description:
+    Git is a free and open source distributed version control system
+    designed to handle everything from small to very large projects with
+    speed and efficiency.
+```
+
+### Install Software Package
+
+`spack install` will install any package shown by `spack list`. For example, To install the latest version of the `git` package, you might type this.
+
+Use `spack install git` for default version or `spack install git@version`.
+
+```console
+~]$ spack install git@2.11.0
+==> Installing git
+==> Installing pcre
+==> Fetching http://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.bz2
+...
+```
+
+! warning
+  `ftp` on cluster is not allowed, you must edit source link (edit)[#Edit Rule]
+
+### Edit Rule
+
+```console
+~]$ spack edit git
+```
+
+! note
+  For change source link (ftp:// to http://) use `spack create URL -f`. Automatically generates rules.
+
+**Example**
+
+```console
+~]$ spack install git
+==> Installing git
+==> Installing pcre
+==> Fetching ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.bz2
+curl: (7) couldn't connect to host
+==> Fetching from ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.bz2 failed.
+==> Error: FetchError: All fetchers failed for pcre-8.39-bm3lumpbghly2l7bkjsi4n2l3jyam6ax
+...
+
+~]$ spack create http://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.bz2 -f
+==> This looks like a URL for pcre
+==> Found 2 versions of pcre:
+  
+  8.41  http://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.41.tar.bz2
+  8.40  http://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.40.tar.bz2
+
+How many would you like to checksum? (default is 1, q to abort) 1
+==> Downloading...
+==> Fetching http://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.41.tar.bz2
+######################################################################## 100,0%
+==> Checksummed 1 version of pcre
+==> This package looks like it uses the cmake build system
+==> Created template for pcre package
+==> Created package file: ~/.local/easybuild/software/Spack/0.10.0/var/spack/repos/builtin/packages/pcre/package.py
+~]$
+~]$ spack install git
+==> Installing git
+==> Installing pcre
+==> Installing cmake
+==> Installing ncurses
+==> Fetching http://ftp.gnu.org/pub/gnu/ncurses/ncurses-6.0.tar.gz
+######################################################################## 100,0%
+...
+```
+
+## Available Spack Module
+
+We know that `spack list` shows you the names of available packages, but how do you figure out which are already installed?
+
+```console
+==> 19 installed packages.
+-- linux-centos6-x86_64 / gcc@4.4.7 -----------------------------
+autoconf@2.69  cmake@3.7.1  expat@2.2.0       git@2.11.0     libsigsegv@2.10  m4@1.4.17    openssl@1.0.2j  perl@5.24.0        tar@1.29  zlib@1.2.10
+bzip2@1.0.6    curl@7.50.3  gettext@0.19.8.1  libiconv@1.14  libxml2@2.9.4    ncurses@6.0  pcre@8.41       pkg-config@0.29.1  xz@5.2.2
+```
+
+**Spack colorizes output**
+
+```console
+~]$ spack find | less -R
+```
+
+`spack find` shows the specs of installed packages. A spec is like a name, but it has a version, compiler, architecture, and build options associated with it. In spack, you can have many installations of the same package with different specs.
+
+## Load And Unload Module
+
+Neither of these is particularly pretty, easy to remember, or easy to type. Luckily, Spack has its own interface for using modules and dotkits.
+
+```console
+~]$ spack load git
+==> This command requires spack's shell integration.
+  
+  To initialize spack's shell commands, you must run one of
+  the commands below.  Choose the right command for your shell.
+  
+  For bash and zsh:
+      . ~/.local/easybuild/software/Spack/0.10.0/share/spack/setup-env.sh
+  
+  For csh and tcsh:
+      setenv SPACK_ROOT ~/.local/easybuild/software/Spack/0.10.0
+      source ~/.local/easybuild/software/Spack/0.10.0/share/spack/setup-env.csh
+```
+
+**First usage**
+
+```console
+~]$ . ~/.local/easybuild/software/Spack/0.10.0/share/spack/setup-env.sh
+```
+
+```console
+~]$ git version 1.7.1
+~]$ spack load git
+~]$ git --version
+git version 2.11.0
+~]$ spack unload git
+~]$ git --version
+git version 1.7.1
+```
+
+## Uninstall Software Package
+
+Spack will ask you either to provide a version number to remove the ambiguity or use the `--all` option to uninstall all of the matching packages.
+
+You may force uninstall a package with the `--force` option
+
+``console
+~]$ spack uninstall git
+==> The following packages will be uninstalled : 
+
+-- linux-centos6-x86_64 / gcc@4.4.7 -----------------------------
+xmh3hmb git@2.11.0%gcc
+
+
+==> Do you want to proceed ? [y/n]
+y
+==> Successfully uninstalled git@2.11.0%gcc@4.4.7 arch=linux-centos6-x86_64 -xmh3hmb
+
+```
+
diff --git a/mkdocs.yml b/mkdocs.yml
index 4b8091537..a670e39c7 100644
--- a/mkdocs.yml
+++ b/mkdocs.yml
@@ -62,6 +62,7 @@ pages:
     - Modules Matrix: modules-matrix.md
     - Singularity Container: software/singularity.md  
     - EasyBuild: software/easybuild.md
+    - EasyBuild: software/spack.md
     - Salomon Software:
       - Available Modules: modules-salomon.md
       - Available Modules on UV: modules-salomon-uv.md
-- 
GitLab