Skip to content

Commit

Permalink
Move images and reformat (#604)
Browse files Browse the repository at this point in the history
  • Loading branch information
psakievich authored May 1, 2024
1 parent 231a5a1 commit 5ccfe54
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 15 deletions.
15 changes: 14 additions & 1 deletion docs/general/spack_manager_structure.md
Original file line number Diff line number Diff line change
@@ -1,11 +1,20 @@
# Spack-Manager Structure

Spack-Manager is a Spack extension that provides a way for software applications
to configure their usage of spack.
to configure their usage of spack.

<img src="../images/application-workflow.png" width="100%">

<p>An example of generalized infrastructure requirements that are common across HPC and scientific computing applications. Spack-Manager's goal is to empower these types of infrastructures while still allowing application teams to drive the details.</p>

The code of Spack-Manager is independent of each individual application and each
application code needs to configure a Spack-Manager `Project` to tell Spack-Manager how to work
with their application.

<img src="../images/Spack-Manager-Org.png" width="50%">

<p>Spack-Manager is designed to provide an abstraction that can support multiple application teams. Each team develops a Project that can be registered with an instance of Spack-Manager.</p>

A `Project` at its core is simply a collection of [spack configuration files](https://spack.readthedocs.io/en/latest/configuration.html),
and [spack package repositories](https://spack.readthedocs.io/en/latest/repositories.html).
A few other optional hooks will be discussed below.
Expand All @@ -27,3 +36,7 @@ spack-manager:
```
Information on configuring a new `Project` can be found in the system administrator profile documentation [here](https://sandialabs.github.io/spack-manager/user_profiles/system_admins/creating_a_project.html).

<img src="../images/ApplicationSpace.png" width="100%">

<p>The end goal of many code application and DevOps teams is to efficiently span the space of platform permutations and project variations.</p>
Binary file modified docs/images/Spack-To-Applications.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
21 changes: 7 additions & 14 deletions docs/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,13 @@ Spack-Manager is quite literal in its name, in that it provides a way to manage
across multiple machines, and multiple projets.

.. image:: images/Spack-To-Applications.png

Check failure on line 13 in docs/index.rst

View workflow job for this annotation

GitHub Actions / docs

ERROR: Error in "image" directive:
:alt: Spack is serving the package management needs of thousands of software packages. However, individual application teams wish to harness the power of Spack for their individual applications specific needs. This naturally leads to redundant, similar workflows.
:alt: Spack is central to applications, but applications often want to further customize their interfaces and interactions with Spack
:width: 75%

Spack is serving the package management needs of thousands of software packages.
However, individual application teams wish to harness the power of Spack for their individual applications specific needs.
This naturally leads to redundant, similar workflows.

The intent of this project is to maintain as thin of a buffer as possible between software packages and Spack, and to be pushing ideas and workflow
improvements back to Spack on a regular basis to reduce the code that is maintained here.
As such we do not try to fully mask Spack's workflow or commands from users, but rather expose them at a level appropriate for the user type.
Expand All @@ -32,6 +36,8 @@ decreases as the user becomes further removed from the build process. The three
:alt: Population size of each profile is inverserly proportional to the Spack knowledge required for their roles
:width: 70%

Population size of each profile is inverserly proportional to the Spack knowledge required for their roles

Separate documentation exists for each of these user profiles.

.. toctree::
Expand All @@ -47,30 +53,17 @@ Benefits of Spack-Manager
Spack's `custom extensions <https://spack.readthedocs.io/en/latest/extensions.html>`_ to allow for prototyping at the project level, as well as the option to
maintain features that are only intended for the project's development team.

.. image:: images/Spack-Manager-Org.png
:alt: Spack-Manager is designed to provide an abstraction that can support multiple application teams. Each team develops a Project that can be registered with an instance of Spack-Manager.
:width: 90%

- Spack-Manager maximizes overlap between the workflows of the three user profiles.
The main thought behind Spack-Manager is that the exact same infrastructure that the system administrators use to deploy binaries and modules on various machines
can be recycled to run nightly tests, generate time stamped snapshots of binaries for developers to link against, and supply end users
with production executables.
This framework is stitched together through Spack, but the end products (binaries and modules) are designed to be as independent from Spack as possible.

.. image:: images/application-workflow.png
:alt: An example of generalized infrastruture requirements that are common across HPC and scientific computing applications. Spack-Manager's goal is to empower these types of infrastructures while still allowing application teams to drive the details.
:width: 90%

- Spack-Manager provides the benefits of Spack by seeking to maintain as small of a wrapper layer as possible. Some of these benefits include:
- Build reproducibiilty, and scalability
- Buy-in and feedback from HPC vendors and software developers over thousands of projects
- Support options, extended documentation and testing through the much larger Spack project

.. image:: images/ApplicationSpace.png
:alt: The end goal of many code application and DevOps teams is to efficiently span the space of platform permutations and project variations.
:width: 90%


Additional details about the philosophy, and general knowledge can be found in the following documentation section.

.. toctree::
Expand Down

0 comments on commit 5ccfe54

Please sign in to comment.