工具篇|一文入门Singularity

内容预览

  • 什么是软件容器(有什么好处?)
  • 什么是Singularity?
  • 构建Singularity容器
  • 容器构建流程图

什么是软件容器(有什么好处?)

关于容器技术,在以往的文章中已介绍过一次。
本文重点介绍Singularity的必需技术,以及如何构建一个属于自己的容器,在全文最后,附上一张构建容器的流程图供大家参考。

首先以实际应用例子来说,借助于容器技术我们可以实现哪些操作?

  • 打包分析管道,使其在您的笔记本电脑、云端和高性能计算 (HPC) 环境中运行,以产生相同的结果。

  • 发表论文并包含指向包含您使用的所有数据和软件的容器的链接,以便其他人可以轻松重现您的结果。

  • 通过几次击键即可安装并运行需要复杂依赖关系堆栈的应用程序。

  • 创建管道或复杂的工作流程,其中每个单独的程序都应在不同的操作系统上运行。

👉
想必很多同学遇到过这样的场景

在本地电脑上调试好的分析软件,即使是同样的安装手册,在实验室/超算中心的电脑上,死活装不上,遇到各种奇怪的报错,例如make失败、cpp预处理器版本不支持、安装perl软件的cpan包依赖安装失败等等。

因此,对于刚开始接触信息分析的小伙伴来说,掌握这门技术,对于实现分析稳定复现、在高性能服务器上快速配置分析管道等都有非常重要的作用

什么是Singularity?

Singularity与Docker一样,都是容器技术的一种。

尽管,Singularity确实存在一些不可忽视的弱点,例如比Docker更不成熟以及更小的社区用户。

其真正的优势在于高性能服务器上部署分析管道时,无需root权限、安全性以及低成本的入门学习,并且能无缝地将Docker容器转换为singularity容器。

而Docker无论是容器构建、运行、生成的结果文件,都需要root权限,这对于用户使用来说非常不方便。

Singularity的快速安装

首先,我们需要确保一些必需的包已经得到安装

在Ubuntu中(根据linux系统选择)

$ sudo apt-get update

$ sudo apt-get install -y build-essential libssl-dev uuid-dev libgpgme11-dev \
    squashfs-tools libseccomp-dev wget pkg-config git cryptsetup debootstrap

在Centos中(根据linux系统选择)

$ sudo yum -y update 

$ sudo yum -y groupinstall 'Development Tools'

$ sudo yum -y install wget epel-release

$ sudo yum -y install debootstrap.noarch squashfs-tools openssl-devel \
    libuuid-devel gpgme-devel libseccomp-devel cryptsetup-luks

接着,singularity使用Golang编写,因此需要安装Go语言

$ wget https://dl.google.com/go/go1.13.linux-amd64.tar.gz

$ sudo tar --directory=/usr/local -xzvf go1.13.linux-amd64.tar.gz
# 此处将Go添加到临时环境中,如果需要开机自启,请修改~/.bashrc文件
$ export PATH=/usr/local/go/bin:$PATH

# 解压
$ wget https://github.com/singularityware/singularity/releases/download/v3.5.3/singularity-3.5.3.tar.gz

$ tar -xzvf singularity-3.5.3.tar.gz

之后,构建安装singularity

$ cd singularity

$ ./mconfig

$ cd builddir

$ make

$ sudo make install

如果希望singularity支持tab补全

$ . etc/bash_completion.d/singularity

$ sudo cp etc/bash_completion.d/singularity /etc/bash_completion.d/

最后,测试安装

$ singularity run library://godlovedc/funny/lolcow

# 如果安装正常,则会出现以下内容:
INFO:    Downloading library image
 _______________________________________
/ Excellent day for putting Slinkies on \
\ an escalator.                         /
 ---------------------------------------
        \   ^__^
         \  (oo)\_______
            (__)\       )\/\
                ||----w |
                ||     ||

Singularity容器下载

在线的容器库:

  • The Singularity Container Library, 由 Sylabs 开发和维护

  • Docker Hub, 由 Docker 开发和维护

  • Quay.io, 由红帽开发和维护

  • NGC, 由 NVIDIA 开发和维护

  • BioContainers, 由 Bioconda 集团开发和维护

  • Amazon AWS、Microsoft Azure 和 Google Cloud 等云提供商也拥有可与 Singularity 配合使用的容器注册表

类似于docker,singularity也能从网络上使用pull命令来下载容器

# 从singularity库下载容器
$ singularity pull library://godlovedc/funny/lolcow
# 下载完成后,将会看见一个sif结尾的文件,这个就是singularity的容器文件
lolcow_latest.sif
# 也可以从docker库下载容器
$ singularity pull docker://godlovedc/lolcow

Singularity容器使用

进入容器:shell命令

$ singularity shell lolcow_latest.sif

退出容器:exit命令

# 在容器环境中
Singularity> exit
# 就会返回到真实环境下
~>

在容器内执行任务:exec命令

$ singularity exec lolcow_latest.sif cowsay 'How did you get out of the container?'
 _______________________________________
< How did you get out of the container? >
 ---------------------------------------
        \   ^__^
         \  (oo)\_______
            (__)\       )\/\
                ||----w |
                ||     ||

运行容器:run命令

$ singularity run lolcow_latest.sif
# 此处的run,实际上是调用容器内的一个runscript的特殊文件

# 检查容器内的runscript文件
$ singularity inspect --runscript lolcow_latest.sif
#!/bin/sh

    fortune | cowsay | lolcat
    
# 此外,也可以像运行软件一样来使用容器,例如
./lolcow_latest.sif

构建Singularity容器

要构建一个容器,必须使用build命令

一个标准的容器开发周期为:

  1. 编写一个可写的容器(sandbox)

  2. 使用--writeable进入容器,以交互方式对容器进行修改

  3. 对文件进行修改

  4. 重新build

  5. 重复前两步,直到容器变成我们期望的状态

  6. build并保存容器,以供生产使用

例如我们手头已经有一个现成的recipes(用于build的命令文件)

BootStrap: debootstrap
OSVersion: stable
MirrorURL: http://ftp.us.debian.org/debian/

%runscript
    echo "This is what happens when you run the container..."

%post
    echo "Hello from inside the container"
    apt-get -y --allow-unauthenticated install vim

在这个文件中,%开头的通常表示在构建过程中起着一定特殊作用,具体可以参考文档:https://docs.sylabs.io/guides/3.5/user-guide/definition_files.html

常用的符号有:

%post(执行命令,如下载、安装、编写配置文件、创建目录等)

%files(将文件复制到容器中)

%test(构建完成后,测试容器)

%environment(设置环境变量,类似于修改.bashrc)

%runscript(比较特殊,在呼出容器时,可以自动执行计划的任务)

从头构建一个容器

对于新手而言,通常在build容器时,需要给出--sandbox选项,这在我们还不知道容器开发具体需要包含什么文件的时候,非常有用

开始build容器

$ sudo singularity build --sandbox lolcow lolcow.def

运行完成后,会在当前目录下看到一个lolcow文件

对容器进行探索和修改

$ sudo singularity shell --writable lolcow
Singularity> apt-get update
Singularity> apt-get install -y fortune cowsay lolcat

此时可以看到应用程序成功安装,但如果没有使用--writeable参数,那么在进入容器后,执行安装命令,通常会被告知这些文件都是read-only,不可修改

需要说明的是,与docker类似,在容器中进行的操作,在退出容器后,这些修改并不会保存,如果要使这些修改永久生效,就需要将这些操作加入到定义文件中,重新build

从现有容器构建

从现有容器构建,需要注意的是,要修改build定义文件的header

例如需要以容器库中现有的容器作为起点

# 例如以debian为起点
BootStrap: library
From: debian
# 或者从docker hub上的debian启动
Bootstrap: docker
From: debian
# 再或者以本地文件系统上的基础容器启动
Bootstrap: localimage
From: /home/test/debian.sif

与从头构建容器相比,从现有容器构建的最大好处是不需要root权限

$ singularity build debian3.sif debian2.sif

安全的构建容器

在singularity中,提供了--fakeroot选项,可以以更安全的方式在容器中使用root权限来build容器

$ singularity build --fakeroot container.sif container.def

容器挂载主机文件

默认情况下,容器运行后会自动绑定主机的几个目录,包括:

$HOME

/tmp

/proc

/sys

/dev

此外,也可以使用--bind/-B/SINGULARITY_BINDPATH来指定需要绑定的其他目录

至此,你已经掌握了构建一个singularity容器的必须技能了,可以去尝试构建一个属于自己的容器。

容器构建流程图

本文由博客一文多发平台 OpenWrite 发布!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容