Skip to the content.

Singularity

Previously, I had to build Docker images and then convert them to Singularity images on my Mac then transfer them to C4. For large images, clearly this too a while. Recently, the cluster has been modified to allow the creation of images without --remote. In addition, I have found a script that allows the creation of a singularity recipe from a docker recipe.

pip install spython
spython recipe docker2singularity Dockerfile > Singularity.def

With these new bits of knowledge, singularity images became much more useable.

Much, but not all, of what is noted below is now irrelevant.


Archive

If you have a singularity image, it is pretty straight forward. iMOKA is run solely through an image.

Passing files into and out of the image is usually done via a bound path. This can be done with a parameter or an environment variable. iMOKA needed the environment variable. Perhaps the code explicitly uses the environment variable.

export SINGULARITY_BINDPATH=/francislab,/scratch

singularity exec ${img} iMOKA_core reduce \
	--input ${TMPDIR}/matrix.json \
	--output ${TMPDIR}/reduced.matrix

iMOKA uses Dockerfiles, but singularity to build the container. Not sure why.

Singularity does not natively run on Mac so building on my Mac is not a viable solution.

Building on C4 is tricky. Normally, you need root / sudo permission to build.

There is a --fakeroot option, but that doesn't seem to work either.

Then there's the --remote option which apparently does.

There are a few issues expected. Let's see.

The build apparently happens remotely, so any files that need to be included in the image need to be in the cloud.

Apparently you need a token from the remote server which will require a user.

I'm using the default server https://cloud.sylabs.io/

I created a user with my Google login.

Clicked on my username, then Access Tokens, Create New Access Token, Download Token.

singularity remote login --tokenfile ~/sylabs-token 

singularity build --remote TEfinder.img TEfinder

This worked.

Building on a remote server leaves builds and running instances on said server. There seems to be a limit after which build will silently hang. You'll need to login to the remote build server and cleanup.

C4 is developing a singularity build server.

singularity exec TEfinder.img ls /
bin  boot  c4  data  dev  environment  etc  home  lib  lib64  media  mnt  opt  proc  root  run	sbin  singularity  srv	sys  tmp  usr  var

singularity exec TEfinder.img whoami
gwendt

The C4 environment makes bash scripts to error but still run?

singularity exec TEfinder.img TEfinder

/bin/bash: BASH_FUNC_ml(): line 0: syntax error near unexpected token `)'
/bin/bash: BASH_FUNC_ml(): line 0: `BASH_FUNC_ml() () {  eval $($LMOD_DIR/ml_cmd "$@")'
/bin/bash: error importing function definition for `BASH_FUNC_ml'
/bin/bash: BASH_FUNC_module(): line 0: syntax error near unexpected token `)'
/bin/bash: BASH_FUNC_module(): line 0: `BASH_FUNC_module() () {  eval $($LMOD_CMD bash "$@") && eval $(${LMOD_SETTARG_CMD:-:} -s sh)'
/bin/bash: error importing function definition for `BASH_FUNC_module'
One or more required parameters are missing.
example: TEfinder -alignment sample.bam -fa reference.fa -gtf TEs.gtf -te List_of_TEs.txt

There are a number of environment variables that could be the issue.

singularity exec TEfinder.img env

Call with --cleanenv until I figure out exactly what the issue is.

singularity exec --cleanenv TEfinder.img TEfinder

singularity exec --cleanenv TEfinder.img env

Not sure why iMOKA's preprocess.sh doesn't complain. Perhaps cause its a Dockerfile build? Or simply a different linux core? bash is 5.0.17

Using

Bootstrap: docker
From: ubuntu:bionic

instead of

Bootstrap: shub
From: singularityhub/ubuntu

increase the bash version from 4.3.8 to 4.4.20 and the bash function errors go away. Not sure if there are other differences.

Even better

Bootstrap: library
From: ubuntu:20.04

bash 5.0

No errors or --cleanenv needed. Looks cleaner, more generic and more current.

Building on this remote server, at least using the free version, there appears to be a size limit. The account has a limit of 10GB. Apparently there can be a lot of remnants left that take up space. There was 7GB of stuff hidden somewhere in my account.

Also, a limit on build time. Not sure what the denominator is. Per week? Month?

cumulative build time (17h21m12.795s) larger than allowed (16h40m0s)Build 6218141f4a28720818657ba7 cancelled: cumulative build time (17h21m12.795s) larger than allowed (16h40m0s)

Installing Singularity on a Mac

https://sylabs.io/guides/3.0/user-guide/installation.html#install-on-windows-or-mac

/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

brew install --cask virtualbox && brew install --cask vagrant && brew install --cask vagrant-manager && brew install --cask vagrant-vmware-utility

REBOOT your main machine.

The current dir is shared with the virtual machine as /vagrant.

cd ~/github/ucsffrancislab/genomics/singularity

#vagrant init sylabs/singularity-3.0-ubuntu-bionic64 
#vagrant init sylabs/singularity-3.7-ubuntu-bionic64 
vagrant init sylabs/singularity-ce-3.9-ubuntu-bionic64 

vagrant up

vagrant ssh

singularity version

cd /vagrant/

sudo singularity build McClintock.img McClintock | tee McClintock.out
sudo singularity build RepEnrich2.img RepEnrich2 | tee RepEnrich2.out
sudo singularity build SQuIRE.img SQuIRE | tee SQuIRE.out
sudo singularity build TEfinder.img TEfinder | tee TEfinder.out
sudo singularity build TEtools.img TEtools | tee TEtools.out
sudo singularity build TEtranscripts.img TEtranscripts | tee TEtranscripts.out
sudo singularity build xTea.img xTea | tee xTea.out

vagrant destroy

Old or failed

sudo singularity build GeneTEFlow.img GeneTEFlow | tee GeneTEFlow.out

So the current working dir is shared with vagrant, so

https://vagrantcloud.com/search

2.24	Ubuntu 16.04 LTS (Xenial Xerus)
2.25	Ubuntu 16.10 (Yakkety Yak)
2.26	Ubuntu 17.04 (Zesty Zapus)
2.27	Ubuntu 17.10 (Artful Aardvark)
2.28	Ubuntu 18.04 LTS (Bionic Beaver)  <------ Nothing newer?
2.29	Ubuntu 18.10 (Cosmic Cuttlefish)
2.30	Ubuntu 19.04 (Disco Dingo)
2.31	Ubuntu 19.10 (Eoan Ermine)
2.32	Ubuntu 20.04 LTS (Focal Fossa)
2.33	Ubuntu 20.10 (Groovy Gorilla)
2.34	Ubuntu 21.04 (Hirsute Hippo)
2.35	Ubuntu 21.10 (Impish Indri)
2.36	Ubuntu 22.04 LTS (Jammy Jellyfish)

Singularity on AWS Instance

https://raw.githubusercontent.com/ucsffrancislab/genomics/master/aws/ec2_install_singularity.bash

https://github.com/apptainer/singularity/blob/master/INSTALL.md

sudo apt-get update

sudo apt-get install -y \
    build-essential \
    libseccomp-dev \
    pkg-config \
    squashfs-tools \
    cryptsetup \
    curl wget git 

sudo apt-get -y autoremove

export GOVERSION=1.17.3 OS=linux ARCH=amd64  # change this as you need

wget -O /tmp/go${GOVERSION}.${OS}-${ARCH}.tar.gz \
  https://dl.google.com/go/go${GOVERSION}.${OS}-${ARCH}.tar.gz
sudo tar -C /usr/local -xzf /tmp/go${GOVERSION}.${OS}-${ARCH}.tar.gz

echo 'export PATH=$PATH:/usr/local/go/bin' >> ~/.bashrc
source ~/.bashrc

git clone https://github.com/hpcng/singularity.git
cd singularity

git checkout v3.8.4

./mconfig
cd ./builddir
make
sudo make install

sudo chmod o+r /usr/local/etc/singularity/capability.json

singularity --version

20240912 - Install Singularity on Mac

https://docs.sylabs.io/guides/latest/admin-guide/installation.html#installation-on-windows-or-mac

https://docs.sylabs.io/guides/4.2/admin-guide/installation.html#installation-on-windows-or-mac

Install Lima

with MacPorts ( doesn't seem to actually work )

sudo port install lima

or Homebrew

bash -c "$( curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh )"


(echo; echo 'eval "$(/usr/local/bin/brew shellenv)"') >> $HOME/.bash_profile
eval "$(/usr/local/bin/brew shellenv)"


brew install lima

wget https://raw.githubusercontent.com/sylabs/singularity/main/examples/lima/singularity-ce.yml



#	Enable ssh. System Preferences > Sharing > Remote Login

#	This all worked on my newest mac but I can't get passed the ssh test on my older mac

#	Not entirely sure why, but the macports version always fails 
#	INFO[0024] [hostagent] Starting QEMU (hint: to watch the boot progress, see "/Users/jake/.lima/singularity-ce/serial*.log") 
#	INFO[0024] SSH Local Port: 51582                        
#	INFO[0024] [hostagent] Waiting for the essential requirement 1 of 4: "ssh" 
#	INFO[0034] [hostagent] Waiting for the essential requirement 1 of 4: "ssh" 
#	INFO[0122] [hostagent] Waiting for the essential requirement 1 of 4: "ssh" 
#	INFO[0210] [hostagent] Waiting for the essential requirement 1 of 4: "ssh" 
#	INFO[0298] [hostagent] Waiting for the essential requirement 1 of 4: "ssh" 
#	INFO[0385] [hostagent] Waiting for the essential requirement 1 of 4: "ssh" 
#	INFO[0473] [hostagent] Waiting for the essential requirement 1 of 4: "ssh" 
#	INFO[0560] [hostagent] Waiting for the essential requirement 1 of 4: "ssh" 
#	FATA[0623] did not receive an event with the "running" status 

limactl start ./singularity-ce.yml






limactl shell singularity-ce

#	Or

limactl shell singularity-ce singularity run library://alpine





limactl stop singularity-ce

limactl delete singularity-ce


Lima looks like it can also be installed with MacPorts, which is my favored package manager. I have yet to try this, but it should only change the initial portion of this install.

Extract the definition file used to create the singularity image

If it was originally a singularity image, it is helpful. If it was originally a docker image, it isn't.


cat /.singularity.d/Singularity 

Even with the definition file, it may not be rebuildable. Too many external entities.