Skip to content
This repository has been archived by the owner on Jan 16, 2018. It is now read-only.

Problems with driver_configs #23

Open
mckinsel opened this issue Sep 15, 2017 · 3 comments
Open

Problems with driver_configs #23

mckinsel opened this issue Sep 15, 2017 · 3 comments

Comments

@mckinsel
Copy link
Contributor

Commit c37c79f added support for driver_configs in mounts. But this actually made driver_configs stop working for me. I think there are two reasons. First, if m['driver_config'] is a docker.types.services.DriverConfig, then it is a dict with key Options not "options". And not every DriverConfig will have a "device" option; I think driver options vary by driver.

So this commit leads to KeyErrors for me. If I revert it, then driver_configs work again.

@barrachri
Copy link

Hi @mckinsel, can you past the error?

@mckinsel
Copy link
Contributor Author

mckinsel commented Sep 22, 2017

Sure, this is the error I see in the hub:

     Traceback (most recent call last):
       File "/usr/local/lib/python3.5/dist-packages/tornado/web.py", line 1511, in _execute
         result = yield result
       File "/usr/local/lib/python3.5/dist-packages/jupyterhub/handlers/login.py", line 84, in post
         yield self.spawn_single_user(user)
       File "/usr/local/lib/python3.5/dist-packages/jupyterhub/handlers/base.py", line 328, in spawn_single_user
         yield gen.with_timeout(timedelta(seconds=self.slow_spawn_timeout), f)
       File "/usr/local/lib/python3.5/dist-packages/jupyterhub/user.py", line 261, in spawn
         raise e
       File "/usr/local/lib/python3.5/dist-packages/jupyterhub/user.py", line 229, in spawn
         ip_port = yield gen.with_timeout(timedelta(seconds=spawner.start_timeout), f)
       File "/usr/local/lib/python3.5/dist-packages/swarmspawner-0.2.0a0-py3.5.egg/cassinyspawner/swarmspawner.py", line 298, in start
         device = m['driver_config']['options']['device'].format(
     KeyError: 'options'

@mckinsel
Copy link
Contributor Author

This is what the mount actually contains:

{'type': 'volume', 'driver_config': {'Options': {'backing': 'shared'}, 'Name': 'cloudstor:aws'}, 'read_only': True, 'source': 'ro', 'target': 'ro'}

This is using the cloudstor plugin with Docker for AWS. This is the relevant part of the jupyter config:

cloudstor_shared_config = docker.types.DriverConfig(
    "cloudstor:aws",
    {"backing": "shared"})

shared_resource_mount = {
    "target": "ro",
    "source": "ro",
    "type": "volume",
    "read_only": True,
    "driver_config": cloudstor_shared_config}

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants