Skip to content

Commit

Permalink
chore(slurmctld): charm maintained cgroup config
Browse files Browse the repository at this point in the history
These changes move the cgroup config to the charm constants.py.
  • Loading branch information
jamesbeedy committed Nov 25, 2024
1 parent 46b4f17 commit db212c9
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 10 deletions.
6 changes: 1 addition & 5 deletions charms/slurmctld/charmcraft.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -96,11 +96,7 @@ config:
cgroup-parameters:
type: string
default: |
ConstrainCores=yes
ConstrainDevices=yes
ConstrainRAMSpace=yes
ConstrainSwapSpace=yes
default: ""
description: |
User supplied configuration for `cgroup.conf`.
Expand Down
28 changes: 23 additions & 5 deletions charms/slurmctld/src/charm.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,11 @@
import subprocess
from typing import Any, Dict, List, Optional, Union

from constants import CHARM_MAINTAINED_SLURM_CONF_PARAMETERS, PEER_RELATION
from constants import (
CHARM_MAINTAINED_CGROUP_CONF_PARAMETERS,
CHARM_MAINTAINED_SLURM_CONF_PARAMETERS,
PEER_RELATION,
)
from exceptions import IngressAddressUnavailableError
from interface_slurmd import (
PartitionAvailableEvent,
Expand All @@ -32,7 +36,7 @@
WaitingStatus,
main,
)
from slurmutils.models import CgroupConfig, SlurmConfig
from slurmutils.models import SlurmConfig

from charms.grafana_agent.v0.cos_agent import COSAgentProvider
from charms.hpc_libs.v0.is_container import is_container
Expand Down Expand Up @@ -235,10 +239,13 @@ def _on_write_slurm_conf(
self._slurmctld.service.disable()
self._slurmctld.config.dump(slurm_config)

# Write out any user_supplied_cgroup_parameters to /etc/slurm/cgroup.conf.
if user_supplied_cgroup_parameters := self.config.get("cgroup-parameters", ""):
# Write out any cgroup parameters to /etc/slurm/cgroup.conf.
if not is_container():
self._slurmctld.cgroup.dump(
CgroupConfig.from_str(str(user_supplied_cgroup_parameters))
{
**CHARM_MAINTAINED_CGROUP_CONF_PARAMETERS,
**self._get_user_supplied_cgroup_parameters(),
}
)

self._slurmctld.service.enable()
Expand Down Expand Up @@ -329,6 +336,17 @@ def _get_user_supplied_parameters(self) -> Dict[Any, Any]:
}
return user_supplied_parameters

def _get_user_supplied_cgroup_parameters(self) -> Dict[str, str]:
"""Gather, parse, and return the user supplied cgroup parameters."""
user_supplied_cgroup_parameters = {}
if custom_cgroup_config := self.config.get("cgroup-parameters"):
user_supplied_cgroup_parameters = {
line.split("=")[0]: line.split("=", 1)[1]
for line in str(custom_cgroup_config).split("\n")
if not line.startswith("#") and line.strip() != ""
}
return user_supplied_cgroup_parameters

def _get_new_node_names_from_slurm_config(
self, slurm_config: SlurmConfig
) -> List[Optional[str]]:
Expand Down
7 changes: 7 additions & 0 deletions charms/slurmctld/src/constants.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,13 @@

PEER_RELATION = "slurmctld-peer"

CHARM_MAINTAINED_CGROUP_CONF_PARAMETERS = {
"ConstrainCores": "yes",
"ConstrainDevices": "yes",
"ConstrainRAMSpace": "yes",
"ConstrainSwapSpace": "yes",
}

CHARM_MAINTAINED_SLURM_CONF_PARAMETERS = {
"AuthAltParameters": {"jwt_key": "/var/lib/slurm/checkpoint/jwt_hs256.key"},
"AuthAltTypes": ["auth/jwt"],
Expand Down

0 comments on commit db212c9

Please sign in to comment.