.. _label-running-role-of-pmix-and-prte:
The role of PMIx and PRRTE
==========================
Prior versions of Open MPI were layered on top of the Open
Run-Time Environment (ORTE). ORTE originally started as a small
portion of the Open MPI code base, but over time, ORTE effectively
spun off into its own sub-project. ORTE ultimately evolved into the
`Process Management Interface Exascale (PMIx) standard and
corresponding OpenPMIx software project `_.
The OpenPMIx project then evolved its own `PMIx Reference Run-Time
Environment (PRRTE) `_ project.
PRRTE has effectively replaced ORTE in the Open MPI implementation.
Open MPI uses both of these external packages for its run-time system support.
Both PMIx and PRRTE have many configure- and run-time options. Open
MPI attempts to hide most of these details from the end user, and
instead present a unified "everything is Open MPI" interface. Open
MPI will translate configuration directives to PMIx and PRRTE as
relevant, hiding such minutia from the end-user.
This is an intentional design decision on the part of the Open MPI
developer community: HPC and MPI are complicated enough. We do not
want to burden the average end user with needing to understand which
abstractions and configuration options belong to Open MPI vs. PMIx
vs. PRRTE.
Advanced users can peek into the PMIx and PRRTE internals and tweak
additional configuration settings if necessary, but we hope that that
will rarely be necessary.
PMIx
----
The `Process Management Interface for Exascale (PMIx)
`_ package is used by Open MPI for the management,
communication, and coordination of MPI processes with a back-end
run-time system.
The "back-end run-time system" may range from a low-infrastructure
system that simply uses ``ssh`` to remotely execute commands (with no
other infrastructure) to an environment with a full-featured resource
manager and scheduler such as Slurm, PBS/Pro/Torque, or LSF.
PMIx presents a unified API that hides many of the complexities of
communication with these back-end run-time environments. Open MPI
uses the PMIx API to discover, communicate, and coordinate with any
supported back-end run-time system without needing to know the
intimiate details of that system.
PRRTE
-----
The `PMIx Reference Runtime Environment
`_ is, as its name implies, a
reference run-time environment that utilizes the PMIx API. It mainly
provides run-time environment infrastructure for environments that do
not natively have them. In practical terms, this typically means
providing infrastructure for non-scheduled environments that have no
concept of distributed scheduling, file staging, remote stdout/stderr
redirection, and only have ``ssh`` to execute commands on remote
nodes.
Open MPI uses PRRTE to deal with the practical issues of the back-end
run-time environment such as launching, monitoring, killing, and
reaping remote processes.