Newer
Older
# The spawner is based on PRP's https://gitlab.nrp-nautilus.io/vpeddu/jupyterlab-west.git
# This file is managed by [youngsu.kim|dung.vu]@csusb.edu
from kubespawner import KubeSpawner
class MySpawner(KubeSpawner):
with open('/etc/jupyterhub/custom/my_spawner.html', 'r') as f:
profile_form_template = f.readlines()
profile_form_template = "".join(profile_form_template)
def options_from_form(self, formdata):
if not self.profile_list or not hasattr(self, '_profile_list'):
return formdata
selected_profile = int(formdata.get('profile', [0])[0])
options = self._profile_list[selected_profile]
self.log.debug("Applying KubeSpawner override for profile '%s'", options['display_name'])
kubespawner_override = options.get('kubespawner_override', {})
for k, v in kubespawner_override.items():
if callable(v):
v = v(self)
self.log.debug(".. overriding KubeSpawner value %s=%s (callable result)", k, v)
else:
self.log.debug(".. overriding KubeSpawner value %s=%s", k, v)
setattr(self, k, v)
gpus = int(formdata.get('gpus', [0])[0])
setattr(self, "extra_resource_limits", {"nvidia.com/gpu": gpus})
setattr(self, "mem_guarantee", formdata.get('ram', [0])[0]+"G")
setattr(self, "cpu_guarantee", float(formdata.get('cores', [0])[0]))
setattr(self, "mem_limit", formdata.get('ram', [0])[0]+"G")
setattr(self, "cpu_limit", float(formdata.get('cores', [0])[0]))
nodeSelectorTermsExpressions = [{
'key': 'topology.kubernetes.io/region',
'operator': 'In',
}]
if formdata.get('gputype', [0])[0]:
nodeSelectorTermsExpressions.append({
'key': 'nvidia.com/gpu.product',
'operator': 'In',
'values': formdata.get('gputype', [0])
})
tolerationsExpression = [{
'key': 'nautilus.io/nrp-testing',
'operator': 'Exists',
'effect': 'NoSchedule',
},
{
'key': 'nautilus.io/testing',
'operator': 'Exists',
'effect': 'NoSchedule',
setattr(self, 'extra_pod_config', {
'affinity': {
'nodeAffinity': {
'requiredDuringSchedulingIgnoredDuringExecution': {
'nodeSelectorTerms': [{
'matchExpressions': nodeSelectorTermsExpressions,
}],
},
},
setattr(self, 'startTimeout', 1200)
return options
profile_list = [
{
'display_name': 'Nrp-Stack Desktop',
'kubespawner_override': {
# 'image': 'localhost:30081/prp/jupyter-stack/5g-desktop:ab90e952',
# 'image': 'localhost:30081/prp/jupyter-stack/prism-desktop:0addcd15',
'image': 'localhost:30081/prp/jupyter-stack/desktop:ab90e952',
# 'image': 'localhost:30081/prp/jupyter-stack/relion-desktop',
'lifecycle_hooks': {
'postStart': {
'exec': {
'command': [
'sh',
'-c',
'mkdir -p /home/jovyan/Desktop && cp /home/jovyan/shared/.software/desktopInit.desktop /home/jovyan/Desktop/ || true'
]
}
}
}
}
},
'display_name': 'Nrp-Stack Desktop - Visual Code, mutiple Apps',
'image': 'localhost:30081/prp/jupyter-stack/5g-desktop:ab90e952',
# 'image': 'localhost:30081/prp/jupyter-stack/prism-desktop:0addcd15',
# 'image': 'localhost:30081/prp/jupyter-stack/desktop:ab90e952',
# 'image': 'localhost:30081/prp/jupyter-stack/relion-desktop',
'postStart': {
'exec': {
'command': [
'sh',
'-c',
'mkdir -p /home/jovyan/Desktop && cp /home/jovyan/shared/.software/desktopInit.desktop /home/jovyan/Desktop/ || true'
'image': 'localhost:30081/prp/jupyter-stack/datascience:0addcd15',
{
'display_name': 'Nrp-Stack Tensorflow + PRP Packages',
'image': 'localhost:30081/prp/jupyter-stack/prp:0addcd15',
'image': 'localhost:30081/prp/jupyter-stack/r-studio:ab90e952',
'kubespawner_override': {
'image': 'localhost:30081/prp/jupyter-stack/matlab',
}
},
{
'image': 'localhost:30081/prp/jupyter-stack/osgeo-notebook:0addcd15',
'lifecycle_hooks': {
'postStart': {
'exec': {
'command': [
'sh',
'-c',
'mkdir -p /home/jovyan/Desktop && cp /home/jovyan/shared/.software/desktopInit.desktop /home/jovyan/Desktop/ || true'
]
}
}
}
'image': 'localhost:30081/prp/jupyter-stack/5g-desktop:ab90e952',
'lifecycle_hooks': {
'postStart': {
'exec': {
'command': [
'sh',
'-c',
'mkdir -p /home/jovyan/Desktop && cp /home/jovyan/shared/.software/desktopInit.desktop /home/jovyan/Desktop/ || true'
]
}
}
}
'image': 'localhost:30081/prp/jupyter-stack/wcsng-desktop:ab90e952',
'lifecycle_hooks': {
'postStart': {
'exec': {
'command': [
'sh',
'-c',
'mkdir -p /home/jovyan/Desktop && cp /home/jovyan/shared/.software/desktopInit.desktop /home/jovyan/Desktop/ || true'
]
}
}
}
'image': 'localhost:30081/prp/jupyter-stack/prism-desktop:0addcd15',
'lifecycle_hooks': {
'postStart': {
'exec': {
'command': [
'sh',
'-c',
'mkdir -p /home/jovyan/Desktop && cp /home/jovyan/shared/.software/desktopInit.desktop /home/jovyan/Desktop/ || true'
]
}
}
}
'image': 'localhost:30081/prp/jupyter-stack/u55c-desktop:ab90e952',
'lifecycle_hooks': {
'postStart': {
'exec': {
'command': [
'sh',
'-c',
'mkdir -p /home/jovyan/Desktop && cp /home/jovyan/shared/.software/desktopInit.desktop /home/jovyan/Desktop/ || true'
]
}
}
}
'image': 'gitlab-registry.nrp-nautilus.io/youngsu_kim/csusb-jupyter-stack/stack-sagemath',
# 'image': 'localhost:30081/prp/jupyter-stack/r-studio',
'image': 'gitlab-registry.nrp-nautilus.io/csusb-prp/csusb-jupyter-stacks/r-studio',
'image': 'gitlab-registry.nrp-nautilus.io/csusb-prp/csusb-jupyter-stacks/r-studio:latest',
{
'display_name': 'jupyter/minimal-notebook',
'kubespawner_override': {
'image': 'jupyter/minimal-notebook',
}
},
{
'display_name': 'jupyter/scipy-notebook',
'kubespawner_override': {
'image': 'jupyter/scipy-notebook',
}
},
{
'display_name': 'jupyter/tensorflow-notebook',
'kubespawner_override': {
'image': 'jupyter/tensorflow-notebook',
}
},
{
'display_name': 'jupyter/pyspark-notebook',
'kubespawner_override': {
'image': 'jupyter/pyspark-notebook',
}
},
{
'display_name': 'jupyter/datascience-notebook',
'kubespawner_override': {
'image': 'jupyter/datascience-notebook',
}
},
{
'display_name': 'jupyter/all-spark-notebook',
'kubespawner_override': {
'image': 'jupyter/all-spark-notebook',
}
},
]
c.JupyterHub.spawner_class = MySpawner