yahoo-eng-team team mailing list archive
-
yahoo-eng-team team
-
Mailing list archive
-
Message #70823
[Bug 1746483] Re: Not able to boot from Volume / Volume snapshot when using isolated_images
There are probably two ways to handle this:
1. Ignore the request in the IsolatedHostsFilter if the
RequestSpec.image(.id) isn't set.
2. In the API code, if creating a server from a bootable volume, and no
image id is provided, get the image id from the volume image metadata
like this:
https://github.com/openstack/nova/blob/2ecb99939ec15057904d1b86c4478def29e193db/nova/compute/api.py#L2971
And then store that on the request spec. However, that might be
confusing later if code assumes that an image id in the request spec
means it wasn't a boot-from-volume request; although we do have utility
code to tell if an instance is boot-from-volume, like here:
https://github.com/openstack/nova/blob/2ecb99939ec15057904d1b86c4478def29e193db/nova/compute/api.py#L2957
Option #2 is probably the more correct, albeit complicated, fix.
** Also affects: nova/ocata
Importance: Undecided
Status: New
** Also affects: nova/pike
Importance: Undecided
Status: New
** Tags removed: nova
** Tags added: scheduler
--
You received this bug notification because you are a member of Yahoo!
Engineering Team, which is subscribed to OpenStack Compute (nova).
https://bugs.launchpad.net/bugs/1746483
Title:
Not able to boot from Volume / Volume snapshot when using
isolated_images
Status in OpenStack Compute (nova):
Triaged
Status in OpenStack Compute (nova) ocata series:
New
Status in OpenStack Compute (nova) pike series:
New
Bug description:
Description
===========
When using isolated_images, isolated_hosts and restrict_isolated_hosts_to_isolated_images=true
I'm not able to create running instance with volume/volume snapshot as a source.
Instance goes to ERROR state with reason:
Failed to compute_task_build_instances: Cannot load 'id' in the base class
Steps to reproduce
==================
1. Set below options in nova.conf:
isolated_images = <id_of_one_of_images>
isolated_hosts = <one_dedicated_compute>
restrict_isolated_hosts_to_isolated_images=true
and append filter 'IsolatedHostsFilter' to the `enabled_filters`
setting.
2. Apply configs & restart nova services
Now tests:
1. Create empty volume
2. Set bootable flag
3. Launch as instance
4. Created instance is in ERROR state.
Second test:
1. Create instance from image
2. create instance snapshot
3. Go to volume snapshots
4. Create as instance
5. Created instance is in ERROR state.
Actual results
================
Not working
Expected results
==================
Working as usual
Environment
==============
Ocata @ ubuntu xenial, Ceph-backed storage
Packages & versions:
ii nova-api 2:15.0.1-0ubuntu1~cloud0 all OpenStack Compute - API frontend
ii nova-common 2:15.0.1-0ubuntu1~cloud0 all OpenStack Compute - common files
ii nova-conductor 2:15.0.1-0ubuntu1~cloud0 all OpenStack Compute - conductor service
ii nova-consoleauth 2:15.0.1-0ubuntu1~cloud0 all OpenStack Compute - Console Authenticator
ii nova-novncproxy 2:15.0.1-0ubuntu1~cloud0 all OpenStack Compute - NoVNC proxy
ii nova-placement-api 2:15.0.1-0ubuntu1~cloud0 all OpenStack Compute - placement API frontend
ii nova-scheduler 2:15.0.1-0ubuntu1~cloud0 all OpenStack Compute - virtual machine scheduler
ii python-nova 2:15.0.1-0ubuntu1~cloud0 all OpenStack Compute Python libraries
ii python-novaclient 2:7.1.0-0ubuntu1~cloud0 all client library for OpenStack Compute API - Python 2.7
Logs
===========
Traceback (most recent call last):#012#012 File "/usr/lib/python2.7
/dist-packages/oslo_messaging/rpc/server.py", line 155, in
_process_incoming#012 res =
self.dispatcher.dispatch(message)#012#012 File "/usr/lib/python2.7
/dist-packages/oslo_messaging/rpc/dispatcher.py", line 222, in
dispatch#012 return self._do_dispatch(endpoint, method, ctxt,
args)#012#012 File "/usr/lib/python2.7/dist-
packages/oslo_messaging/rpc/dispatcher.py", line 192, in
_do_dispatch#012 result = func(ctxt, **new_args)#012#012 File
"/usr/lib/python2.7/dist-packages/oslo_messaging/rpc/server.py", line
218, in inner#012 return func(*args, **kwargs)#012#012 File
"/usr/lib/python2.7/dist-packages/nova/scheduler/manager.py", line 98,
in select_destinations#012 dests =
self.driver.select_destinations(ctxt, spec_obj)#012#012 File
"/usr/lib/python2.7/dist-packages/nova/scheduler/filter_scheduler.py",
line 58, in select_destinations#012 selected_hosts =
self._schedule(context, spec_obj)#012#012 File "/usr/lib/python2.7
/dist-packages/nova/scheduler/filter_scheduler.py", line 110, in
_schedule#012 spec_obj, index=num)#012#012 File
"/usr/lib/python2.7/dist-packages/nova/scheduler/host_manager.py",
line 572, in get_filtered_hosts#012 hosts, spec_obj, index)#012#012
File "/usr/lib/python2.7/dist-packages/nova/filters.py", line 89, in
get_filtered_objects#012 list_objs = list(objs)#012#012 File
"/usr/lib/python2.7/dist-packages/nova/filters.py", line 44, in
filter_all#012 if self._filter_one(obj, spec_obj):#012#012 File
"/usr/lib/python2.7/dist-packages/nova/scheduler/filters/__init__.py",
line 26, in _filter_one#012 return self.host_passes(obj,
filter_properties)#012#012 File "/usr/lib/python2.7/dist-
packages/nova/scheduler/filters/isolated_hosts_filter.py", line 60, in
host_passes#012 image_ref = spec_obj.image.id if spec_obj.image
else None#012#012 File "/usr/lib/python2.7/dist-
packages/oslo_versionedobjects/base.py", line 67, in getter#012
self.obj_load_attr(name)#012#012 File "/usr/lib/python2.7/dist-
packages/oslo_versionedobjects/base.py", line 603, in
obj_load_attr#012 _("Cannot load '%s' in the base class") %
attrname)#012#012NotImplementedError: Cannot load 'id' in the base
class
To manage notifications about this bug go to:
https://bugs.launchpad.net/nova/+bug/1746483/+subscriptions
References