Release Notes

The following are the contents of the RELEASE_NOTES file as distributed with the Slurm source code for this release. Please refer to the NEWS include alongside the source as well for more detailed descriptions of the associated changes, and for bugs fixed within each maintenance release.

RELEASE NOTES FOR SLURM VERSION 20.11

IMPORTANT NOTES:
If using the slurmdbd (Slurm DataBase Daemon) you must update this first.

NOTE: If using a backup DBD you must start the primary first to do any
database conversion, the backup will not start until this has happened.

The 20.11 slurmdbd will work with Slurm daemons of version 19.05 and above.
You will not need to update all clusters at the same time, but it is very
important to update slurmdbd first and having it running before updating
any other clusters making use of it.

Slurm can be upgraded from version 19.05 or 20.02 to version 20.11 without loss
of jobs or other state information. Upgrading directly from an earlier version
of Slurm will result in loss of state information.

If using SPANK plugins that use the Slurm APIs, they should be recompiled when
upgrading Slurm to a new major release.

NOTE: Slurmctld is now set to fatal in case of computing node configured with
      CPUs == #Sockets. CPUs has to be either total number of cores or threads.

NOTE: The FastSchedule option has been removed. The FastSchedule=2 functionality
      (used for testing and development) is available as the new
      SlurmdParameters=config_overrides option.

NOTE: Slurmdbd is now set to fatal if slurmdbd.conf file isn't owned by
      SlurmUser or it's mode is not set to 0600.

HIGHLIGHTS
==========
 -- The example systemd unit files have been changed to the "simple" type of
    operation, and the daemon will now run in the foreground within systemd
    instead of daemonizing itself.
 -- Log messages enabled by the various DebugFlags have been overhauled, and
    will all print at the verbose() level, and prepend the flag name that is
    associated with a given log message.
 -- A separate unversioned libslurm_pmi.so will be installed, and the libpmi.so
    that Slurm can (optionally) install will link to that rather than libslurm.
    This should resolve long-standing issues when building static OpenMPI
    libraries and later updating your Slurm release, thereby breaking the
    embedded libslurm.so. link in those OpenMPI libraries that were
    inherited from libpmi.so.
 -- accounting_storage/filetxt has been removed as an option.  Please consider
    using accounting_storage/slurmdbd as an alternative.
 -- setting of number of Sockets per node was standardized for configuration
    line with and without Boards=. Specifically in case of Boards=1 and #CPUs
    given the default value of Sockets will be set to #CPUs / #Cores / #Threads.
 -- Dynamic Future Nodes - slurmds started with -F[] will be
    associated with a nodename in Slurm that matches the same hardware
    configuration.
 -- SlurmctldParameters=cloud_reg_addrsa - Cloud nodes automatically get
    NodeAddr and NodeHostname set from slurmd registration.
 -- SlurmctldParameters=power_save[_min]_interval - Configure how often the
    power save module looks to do work.
 -- By default, a step started with srun will be granted exclusive (or non-
    overlapping) access to the resources assigned to that step. No other
    parallel step will be allowed to run on the same resources at the same
    time. This replaces one facet of the '--exclusive' option's behavior, but
    does not imply the '--exact' option described below. To get the previous
    default behavior - which allowed parallel steps to share all resources -
    use the new srun '--overlap' option.
 -- In conjunction to this non-overlapping step allocation behavior being the
    new default, there is an additional new option for step management
    '--exact', which will allow a step access to only those resources requested
    by the step. This is the second half of the '--exclusive' behavior.
    Otherwise, by default all non-gres resources on each node in the allocation
    will be used by the step, making it so no other parallel step will have
    access to those resources unless both steps have specified '--overlap'.
 -- --threads-per-core now influences task layout/binding, not just allocation.
 -- AutoDetect in gres.conf can now be specified for some nodes while not for
    others via the NodeName option.
 -- gres.conf - Add new MultipleFiles configuration entry to allow a single
    GRES to manage multiple device files simultaneously.
 -- Remove SallocDefaultCommand option.
 -- Add support for an "Interactive Step", designed to be used with salloc to
    launch a terminal on an allocated compute node automatically. Enable by
    setting "use_interactive_step" as part of LaunchParameters.
 -- Add IPv6 support. Must be explicitly enabled with EnableIPv6 in
    CommunicationParameters. IPv4 support can be disabled with DisableIPv4.
 -- Allow use of a target directory with "srun --bcast", and change the default
    filename to include the node name as well.
 -- Added a new --mail-type=INVALID_DEPEND option to salloc, sbatch, and srun.
 -- Differences between hardware (memory size, number of CPUs) discovered on
    node vs configured in slurm.conf will now throw an error only when the node
    state is set to drain. Previously it was done on every node registration,
    those messages were demoted to debug level.
 -- Added "scrontab", which permits crontab-compatible job scripts to be
    defined. These scripts will recurr automatically (at most) on the intervals
    described.
 -- Enable -lnodes=#:gpus=# in #PBS/qsub -l nodes syntax.
 -- Any user >= Operator can see any hidden partition by default, as SlurmUser
    or root already did.
 -- select/linear will now allocate up to nodes RealMemory when configured with
    SelectTypeParameters=CR_Memory and --mem=0 specified. Previous behavior was
    no memory accouted and no memory limits implied to job.
 -- slurmrestd - add API to interface with slurmdbd.
 -- Add --ntasks-per-gpu option.
 -- Add --gpu-bind=single option.
 -- Fix "scontrol takeover [backup]" hangs when specifying a backup > 1. All
    slurmctlds below the "backup" will be shutdown.
 -- The names of the functions in the cli_filter plugin are now prepended with
    the string "cli_filter_p_". For example, the function setup_defaults()
    was changed to cli_filter_p_setup_defaults().

CONFIGURATION FILE CHANGES (see man appropriate man page for details)
=====================================================================
 -- Removed "cpusets" option from TaskPluginParam. Please use task/cgroup.
 -- Removed MsgAggregationParams.
 -- Removed Layouts.
 -- Remove switch/generic plugin.
 -- The acct_gather_energy/cray_aries plugin has been renamed to
    acct_gather_energy/pm_counters.
 -- The JobCompLoc URL endpoint when the JobCompType=jobcomp/elasticsearch
    plugin is enabled is now fully configurable and the plugin no longer appends
    a hardcoded "/slurm/jobcomp" index and type suffix to it.
 -- Removed support for "default_gbytes" option in SchedulerParameters.

COMMAND CHANGES (see man pages for details)
===========================================
 -- Make sacct get the UID from database instead of from the username and a
    system call. Add --use-local-uid option to sacct to use old behavior.
 -- The '%s' format in -e/-i/-o options to sbatch will expand to "batch" rather
    than "4294967294".
 -- squeue - added "pendingtime" as a option for --Format.
 -- sacct - AllocGres and ReqGres were removed. Alloc/ReqTres should be used
    instead.
 -- scontrol - added the "Reserved" license count to 'scontrol show licenses'.
 -- Add time specification: "now-" (i.e. subtract from the present)
 -- squeue - put sorted start times of "N/A" or 0 at the end of the list.
 -- Change "scontrol reboot ASAP" to use next_state=resume logic.
 -- scontrol - added an admin-settable "Comment" field to each Node.
 -- squeue and sinfo -O no longer repeat the last suffix specified.
 -- salloc now waits for PrologSlurmctld to finish before entering the shell.

API CHANGES
===========
 -- slurm_ctl_conf_t has been renamed to slurm_conf_t.
 -- slurm_free_kvs_comm_set() has been renamed to slurm_pmi_free_kvs_comm_set(),
    slurm_get_kvs_comm_set() has been renamed to slurm_pmi_get_kvs_comm_set().
 -- slurm_job_step_layout_get() parameters has changed to use slurm_step_id_t
    see slurm.h for new implementation.  If not running hetsteps just put
    NO_VAL as the value for step_het_comp.
 -- slurm_job_step_stat() parameters has changed to use slurm_step_id_t
    see slurm.h for new implementation.  If not running hetsteps just put
    NO_VAL as the value for step_het_comp.
 -- slurm_job_step_get_pids() parameters has changed to use slurm_step_id_t
    see slurm.h for new implementation.  If not running hetsteps just put
    NO_VAL as the value for step_het_comp.
 -- slurmdb_selected_step_t has been renamed slurm_selected_step_t.
 -- slurm_sbcast_lookup() arguments have changed.  It now takes a populated
    slurm_selected_step_t instead of job_id, het_job_offset, step_id.
 -- Due to internal restructuring ahead of the 20.11 release, applications
    calling libslurm MUST call slurm_init(NULL) before any API calls.
    Otherwise the API call is likely to fail due to libslurm's internal
    configuration not being available.