Skip to content

A library of container templates to enable reproducible containers for scientific computing

License

Notifications You must be signed in to change notification settings

XSEDE/container-template-lib

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 

Repository files navigation

Container Template Library (CTL) Project Overview

The XSEDE Cyberinfrastructure Resource Integration (XCRI) team has developed the Container Template Library (CTL) which spans several repositories and purposes, all focused on containers for scientific computing. The main goal of the CTL project is to collect a library of templates for scientific computing software containers that can be provided by cluster admins, run directly by users, edited by developers to create new scientific software containers, and used by anyone for learning how to build, develop, deploy, and run containers on XSEDE resources and XSEDE-like campus clusters.

Project Goals & Products

This project is currently in-progress, so you can expect updates and changes here until completion. In the meantime, this list includes both in-progress and completed items:

  • A Library of container templates for scientific computing.
  • There are several container templates that focus on reproducible builds by leveraging the Nix package manager features.
  • We are developing robust testing of the containers on a variety of XSEDE systems using INCA to enable sysadmins and users to feel confident using these containers on their systems.
  • We are integrating this work with the Container Tutorial we have been providing to create a Learning Toolkit that people from a variety of backgrounds can start with to engage with containers for scientific computing.

Questions & Contributing

If you have questions, comments, or suggestions, please feel free to open a new issue or pull request on this repository or send an email to [email protected] with XCRI in the subject line.

Docs

Coming Soon...

Library

Base Templates

These currently exist in other repositories:

  • Docker Nix Base Template - The base Docker container for including the Nix package manager, based off of the original version developed at NixOS.
  • Singularity Nix Base Template - The base Singularity container (converted from the Docker container) for including the Nix package manager.
  • Docker Nix OpenMPI Base Template - A Docker container with Nix to be used as a base template for applications using OpenMPI.
  • Singularity Nix OpenMPI Base Template - A Singularity container (converted from the Docker container) to be used as a base template for applications using OpenMPI. This also includes the Linpack HPL benchmark with a sample slurm job script for testing.
  • CUDA Base Template - Both a Docker and Singularity container with Nix for installing the CUDA 10.2 toolkit; to be used as a base template for GPU-oriented applications.
  • Python Base Template - Both a Docker and Singularity container with Nix for python3 to be used as a base template for python applications.

Software Templates

These currently exist in other repositories:

  • sc-benchmark - Both a Docker and Singularity container with Nix for running the sc-benchmark. This includes setting up R and python using the Nix package manager, and can serve as a template for similar applications.
  • Python Mandle App - Both a Docker and Singularity container with Nix for a python3 application that allows you to create a GIF file with a straight-line zoom-in of the Mandlebrot set, based on the Python Base Template.
  • PerfZero - Both a Docker and Singularity container with Nix for running the Tensorflow PerfZero benchmarks containing both Python and R dependencies.
  • NAMD2.14 - Both a Docker and Singularity container with Nix for running NAMD2.14.

About

A library of container templates to enable reproducible containers for scientific computing

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published