\fBjob_container.conf\fP is an ASCII file which defines parameters used by Slurm's namespace/tmpfs plugin. Based on these parameters, the plugin will create the appropriate job-specifc namespace(s). The namespace/tmpfs plugin creates a filesystem namespace and will construct a private (or optionally shared) filesystem namespace and mount a list of directories (defaults to /tmp and /dev/shm) inside it, giving the job a private view of these directories. These paths are mounted inside the location specified by 'BasePath' in the \fBjob_container.conf\fR file. When the job completes, the namespace is unmounted and all files therein are automatically removed. To make use of this plugin, 'PrologFlags=Contain' must also be present in your \fBslurm.conf\fR file, as shown: .nf NamespaceType=namespace/tmpfs PrologFlags=Contain .fi The file will always be located in the same directory as the \fBslurm.conf\fR. .LP If using the \fBjob_container.conf\fR file to define a namespace available to nodes the first parameter on the line should be \fBNodeName\fR. If configuring a namespace without specifying nodes, the first parameter on the line should be \fBBasePath\fR. .LP Parameter names are case insensitive. Any text following a "#" in the configuration file is treated as a comment through the end of that line. Changes to the configuration file take effect upon restart of Slurm daemons. .LP The following job_container.conf parameters are defined to control the behavior of the namespace/tmpfs plugin. .TP \fBAutoBasePath\fR This determines if plugin should create the BasePath directory or not. Set it to 'true' if directory is not pre\-created before slurm startup. If set to true, the directory is created with permission 0755. Directory is not deleted during slurm shutdown. If set to 'false' or not specified, plugin would expect directory to exist. This option can be used on a global or per\-line basis. This parameter is optional. .IP .TP \fBBasePath\fR Specify the \fIPATH\fR that the tmpfs plugin should use as a base to mount the when trying to mount and unmount the private directories for the job. .IP .TP \fBCloneNSScript\fR Specify fully qualified pathname of an optional initialization script. This script is run after the namespace construction of a job. This script will be provided the SLURM_NS environment variable containing the path to the namespace that can be used by the nsenter command. This variable will allow the script to join the newly created namespace and do further setup work. This parameter is optional. .IP .TP \fBCloneNSScript_Wait\fR The number of seconds to wait for the CloneNSScript to complete before considering the script failed. The default value is 10 seconds. .IP .TP \fBCloneNSEpilog\fR Specify fully qualified pathname of an optional epilog script. This script runs just before the namespace is torn down. This script will be provided the SLURM_NS environment variable containing the path to the namespace that can be used by the nsenter command. This variable will allow the script to join the soon to be removed namespace and do any cleanup work. This parameter is optional. .IP .TP \fBCloneNSEpilog_Wait\fR The number of seconds to wait for the CloneNSEpilog to complete before considering the script failed. The default value is 10 seconds. .IP .TP \fBEntireStepInNS\fR Specifying EntireStepInNS=true will pivot all slurmstepd processes (excluding the external step, which is tasked with creating the namespace) into the constructed namespace. This will cause issues if certain paths such as SlurmdSpoolDir are inaccessible. This parameter is optional. .IP .TP \fBInitScript\fR Specify fully qualified pathname of an optional initialization script. This script is run before the namespace construction of a job. It can be used to make the job join additional namespaces prior to the construction of /tmp namespace or it can be used for any site\-specific setup. This parameter is optional. .IP .TP .SH "NOTES" .LP If any parameters in job_container.conf are changed while slurm is running, then slurmd on the respective nodes will need to be restarted for changes to take effect (scontrol reconfigure is not sufficient). Additionally this can be disruptive to jobs already running on the node. So care must be taken to make sure no jobs are running if any changes to job_container.conf are deployed. Restarting slurmd is safe and non\-disruptive to running jobs, as long as job_container.conf is not changed between restarts in which case above point applies. .SH "EXAMPLE" .TP \fB/etc/slurm/slurm.conf\fR: These are the entries required in \fBslurm.conf\fR to activate the namespace/tmpfs plugin. .IP .nf NamespaceType=namespace/tmpfs PrologFlags=Contain .fi .TP \fB/etc/slurm/job_container.conf\fR: The first sample file will define 1 basepath for all nodes and it will be automatically created. .nf AutoBasePath=true BasePath=/var/nvme/storage .fi The second sample file will define 2 basepaths. The first will only be on largemem[1\-2] and it will be automatically created. The second will only be on gpu[1\-10], will be expected to exist and will run an initscript before each job. .nf NodeName=largemem[1\-2] AutoBasePath=true BasePath=/var/nvme/storage_a NodeName=gpu[1\-10] BasePath=/var/nvme/storage_b InitScript=/etc/slurm/init.sh .fi The third sample file will Define 1 basepath that will be on all nodes, automatically created, with /tmp and /var/tmp as private mounts. .nf AutoBasePath=true BasePath=/var/nvme/storage Dirs=/tmp,/var/tmp .fi .IP .SH "COPYING" Slurm is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. .SH "SEE ALSO" .LP \fBslurm.conf\fR(5)