-
Notifications
You must be signed in to change notification settings - Fork 60
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merge profiles into JupyterHub itself #33
Comments
The master issue will be jupyterhub/jupyterhub#2724, this was just to notify people using wrapspawner and for internal reference. |
Do I understand it correctly that instead of having only "combination parameters" to choose from a simple list, we could set each option individually? For example similarly to this? Is there no other simple way to be able to use multiple spawners (batchspawner's PBS spawner and kubespawner or local process spawner in my case) and be able to choose the parameters (walltime, ncpus, memory, env variables, image etc.) individually before the notebook server is spawned? |
You can have both. What we do is extend WrapSpawner itself (we don't use ProfileSpawner), this lets us show a bunch of buttons on In our deployment the home/console template page is massively complicated but driven completely by our configuration setup and our customized wrapspawner. We had some opinions that we imposed here (like we want users to have only one server per type and that it should have a specific name that we set). I don't quite see how profiles/wrapspawner functionality can easily be integrated into JupyterHub itself without a gigantic refactor, so far wrapspawner meets our needs... |
What you described sounds like exactly I would like to implement in my company. We have a series of clusters connected by a PBS system, and I am in charge of jupyterhub that spawns notebook onto PBS compute nodes using batchspawner's PBSSpawner, as well as using local process spawner (I plan to use kubespawner instead) to spawn notebooks inside the virtual cloud kubernetes cluster where the hub itself runs. Right now I have spawning options set exactly as the wrapspawner's example, just a simple list of pbs parameter combinations (1CPU + 1GB RAM +1 hour, 4 CPUs + 4GB RAM + 8 hours, etc.). This is quite limiting because users would like to set each parameter separately. Would you be so king and provide me with some examples or source codes just to know where to start and what is or is not possible? A screenshot of everything you are able to set would be also nice. I agree that merging this with jupyterhub is a loads of work, in my opinion each spawner should provide its own template for setting spawner settings, similarly to what kubespawner offers, and jupyterhub should maybe only choose the spawner similarly to the wrapspawner manner. |
I discussed the multiple profile selection tools (ProfileSpawner, the one in KubeSpawner, etc) with @minrk at the Oslo JupyterHub sprint. His proposal was that profiles could be merged directly into JupyterHub since they have been proven by now. This could directly select the spawner class, and avoid all of the proxying problems we have here. Most of the other issues in this repo could be closed, too.
This would need at least the features:
To me the biggest unknown is "how do options forms work", since the options form is a property of the spawner class but there can be multiple spawner classes and one isn't chosen until after the options form is rendered and an option is selected.
What do you all think about this?
The text was updated successfully, but these errors were encountered: