From 3cb4f28e7be8a37516493fcc6a609172b038edc5 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?David=20Hrb=C3=A1=C4=8D?= <david@hrbac.cz>
Date: Thu, 16 Feb 2017 16:46:16 +0100
Subject: [PATCH] Singularity draft

---
 docs.it4i/software/singularity.md | 128 ++++++++++++++++++++++++++++++
 mkdocs.yml                        |   1 +
 2 files changed, 129 insertions(+)
 create mode 100644 docs.it4i/software/singularity.md

diff --git a/docs.it4i/software/singularity.md b/docs.it4i/software/singularity.md
new file mode 100644
index 000000000..245f7982a
--- /dev/null
+++ b/docs.it4i/software/singularity.md
@@ -0,0 +1,128 @@
+[Singularity](http://singularity.lbl.gov/) enables users to have full control of their environment. A non-privileged user can "swap out" the operating system on the host for one they control. So if the host system is running RHEL6 but your application runs in Ubuntu/RHEL7, you can create an Ubuntu/RHEL7 image, install your applications into that image, copy the image to another host, and run your application on that host in it’s native Ubuntu/RHEL7 environment.
+
+Singularity also allows you to leverage the resources of whatever host you are on. This includes HPC interconnects, resource managers, file systems, GPUs and/or accelerators, etc. Singularity does this by enabling several key facets:
+
+* Encapsulation of the environment
+* Containers are image based
+* No user contextual changes or root escalation allowed
+* No root owned daemon processes
+
+## Using Docker Images
+
+Singularity can import, bootstrap, and even run Docker images directly from [Docker Hub](https://hub.docker.com/). You can easily run RHEL7 like this:
+
+```bash
+[hrb33@r33u01n865 ~]$ cat /etc/redhat-release 
+CentOS release 6.7 (Final)
+[hrb33@r33u01n865 ~]$ ml Singularity
+[hrb33@r33u01n865 ~]$ singularity shell docker://centos:latest
+library/centos:latest
+Downloading layer: sha256:a3ed95caeb02ffe68cdd9fd84406680ae93d633cb16422d00e8a7c22955b46d4
+Downloading layer: sha256:a3ed95caeb02ffe68cdd9fd84406680ae93d633cb16422d00e8a7c22955b46d4
+Downloading layer: sha256:45a2e645736c4c66ef34acce2407ded21f7a9b231199d3b92d6c9776df264729
+Downloading layer: sha256:a3ed95caeb02ffe68cdd9fd84406680ae93d633cb16422d00e8a7c22955b46d4
+Singularity: Invoking an interactive shell within container...
+
+Singularity.centos:latest> cat /etc/redhat-release 
+CentOS Linux release 7.3.1611 (Core) 
+```
+
+## Creating Own Image from Docker Image
+
+```bash
+hrb33@hrb33-toshiba:/$ cd /tmp/
+hrb33@hrb33-toshiba:/tmp$ sudo singularity create /tmp/c7.img
+[sudo] password for hrb33: 
+Creating a new image with a maximum size of 768MiB...
+Executing image create helper
+Formatting image with ext3 file system
+Done.
+hrb33@hrb33-toshiba:/tmp$ sudo singularity import c7.img docker://centos:latest
+library/centos:latest
+Downloading layer: sha256:a3ed95caeb02ffe68cdd9fd84406680ae93d633cb16422d00e8a7c22955b46d4
+Downloading layer: sha256:a3ed95caeb02ffe68cdd9fd84406680ae93d633cb16422d00e8a7c22955b46d4
+Downloading layer: sha256:45a2e645736c4c66ef34acce2407ded21f7a9b231199d3b92d6c9776df264729
+Downloading layer: sha256:a3ed95caeb02ffe68cdd9fd84406680ae93d633cb16422d00e8a7c22955b46d4
+Adding Docker CMD as Singularity runscript...
+Bootstrap initialization
+No bootstrap definition passed, updating container
+Executing Prebootstrap module
+Executing Postbootstrap module
+Done.
+hrb33@hrb33-toshiba:/tmp$ sudo singularity shell --writable c7.img 
+Singularity: Invoking an interactive shell within container...
+
+Singularity.c7.img> mkdir /apps /scratch
+Singularity.c7.img> exit
+hrb33@hrb33-toshiba:/tmp$ rsync -av c7.img  hrb33@login4.salomon:/home/hrb33/c7.img
+sending incremental file list
+c7.img
+
+sent 805,503,090 bytes  received 34 bytes  9,205,749.99 bytes/sec
+total size is 805,306,399  speedup is 1.00
+
+```
+
+Accessing /HOME and /SCRATCH Within Container
+
+```bash
+hrb33@hrb33-toshiba:/tmp$ ssh hrb33@login4.salomon
+
+                    _____       _                             
+                   / ____|     | |                            
+                  | (___   __ _| | ___  _ __ ___   ___  _ __  
+                   \___ \ / _` | |/ _ \| '_ ` _ \ / _ \| '_ \ 
+                   ____) | (_| | | (_) | | | | | | (_) | | | |
+                  |_____/ \__,_|_|\___/|_| |_| |_|\___/|_| |_|
+
+                        http://www.it4i.cz/?lang=en
+
+
+Last login: Fri Feb 10 14:38:36 2017 from 10.0.131.12
+[hrb33@login4.salomon ~]$ ml Singularity
+[hrb33@login4.salomon ~]$ singularity shell --bind /scratch --bind /apps --writable c7.img 
+Singularity: Invoking an interactive shell within container...
+
+Singularity.c7.img> ls /apps/ -l
+total 68
+drwx------   4 root root   29 Sep 29 10:28 SCS
+drwxrwxr-x 301 2757 2796 8192 Feb 16 10:58 all
+drwxrwxr-x   3 2757 2796   19 Jul  9  2015 base
+drwxrwxr-x  16 2757 2796 4096 Nov 24 21:47 bio
+drwxrwxr-x  10 2757 2796  116 Apr  8  2016 cae
+drwxrwxr-x  18 2757 2796 4096 Jan 17 09:49 chem
+drwxrwxr-x  11 2757 2796  122 Dec  7 09:25 compiler
+drwxrwxr-x   7 2757 2796   73 Jun 29  2016 data
+drwxr-xr-x   7 2757 2796   88 Jan  8  2016 debugger
+drwxrwxr-x  38 2757 2796 4096 Feb 16 13:37 devel
+drwxrwxr-x   9 2757 2796  130 Jan  9 08:40 easybuild
+drwxr-xr-x  11 3900 4011 4096 Feb 15 09:50 gentoo
+drwxr-xr-x  10 3900 4011 4096 Feb 10 17:01 gentoo_uv
+drwxrwxr-x   5 2757 2796   39 Jan 18  2016 geo
+drwxr-xr-x  18 2757 2796 4096 Sep  6 16:03 intel2017
+drwxrwxr-x  20 2757 2796 4096 Nov 28 08:50 lang
+drwxrwxr-x  31 2757 2796 4096 Dec  7 07:48 lib
+drwxrwxr-x   4 2757 2796   32 Nov  9 09:19 licenses
+drwxrwxr-x  17 2757 2796 4096 Nov 15 09:24 math
+drwxr-xr-x  22 2757 2796 4096 Jan 19 13:15 modules
+drwxrwxr-x   8 2757 2796   82 Apr 18  2016 mpi
+drwxrwxr-x  13 2757 2796 4096 Oct 24 09:08 numlib
+drwxrwxr-x  10 2757 2796  108 Feb  3 11:01 perf
+drwxrwxr-x   5 2757 2796   41 Jan 17 09:49 phys
+drwxrwxr-x   2 2757 2796    6 Feb  3 11:01 prace
+drwxr-xr-x   4 root root   36 Jun 18  2015 sw
+drwxrwxr-x   5 2757 2796   49 Feb 15  2016 system
+drwxr-xr-x   3 root root   19 Dec  4  2015 test
+drwxrwxr-x  13 2757 2796  138 May 31  2016 toolchain
+drwxrwxr-x  39 2757 2796 4096 Feb  3 11:27 tools
+drwxr-xr-x   4 root root   31 Aug 11  2015 user
+drwxrwxr-x  21 2757 2796 4096 Jan  5 18:56 uv
+drwxrwxr-x  40 2757 2796 4096 Feb  3 11:01 vis
+Singularity.c7.img> ls /scratch/ -l
+total 32
+drwx------   3 root root  4096 Aug 15  2016 backup
+drwxr-x---   2 root root  4096 Dec  5 10:34 sys
+drwxrwxrwt 154 root root 20480 Feb 14 14:03 temp
+drwxr-xr-x   4 root root  4096 Jan 25 10:48 work
+Singularity.c7.img> 
+```
diff --git a/mkdocs.yml b/mkdocs.yml
index 0d147055f..d81c5045f 100644
--- a/mkdocs.yml
+++ b/mkdocs.yml
@@ -63,6 +63,7 @@ pages:
   - 'Software':
     - Lmod Environment: software/lmod.md
     - Modules Matrix: modules-matrix.md
+    - Singularity Container: software/singularity.md  
     - Salomon Software:
       - Available Modules: modules-salomon.md
       - Available Modules on UV: modules-salomon-uv.md
-- 
GitLab