Cleanup objects that we create on behalf of images

When the use performs create_image on a cloud that requires the image be
uploaded to swift, we upload the image content to swift for them. Once
the image is imported, the content in swift is no longer needed as
glance copies the data into its own area. Clean the images up so that
we're not just accumulating tons of content in swift.

Change-Id: Iede6441c0cad1d99e92fdfacf96d81aad479a93e
This commit is contained in:
Monty Taylor 2017-11-16 08:46:49 -06:00
parent cb79152f50
commit 371e0b667e
No known key found for this signature in database
GPG Key ID: 7BAE94BC7141A594
3 changed files with 33 additions and 0 deletions

View File

@ -0,0 +1,6 @@
---
features:
- If shade has to create objects in swift to upload an
image, it will now delete those objects upon successful
image creation as they are no longer needed. They will
also be deleted on fatal import errors.

View File

@ -4875,6 +4875,9 @@ class OpenStackCloud(
self.log.debug( self.log.debug(
"Image Task %s imported %s in %s", "Image Task %s imported %s in %s",
glance_task.id, image_id, (time.time() - start)) glance_task.id, image_id, (time.time() - start))
# Clean up after ourselves. The object we created is not
# needed after the import is done.
self.delete_object(container, name)
return self.get_image(image_id) return self.get_image(image_id)
elif status['status'] == 'failure': elif status['status'] == 'failure':
if status['message'] == IMAGE_ERROR_396: if status['message'] == IMAGE_ERROR_396:
@ -4882,6 +4885,11 @@ class OpenStackCloud(
'/tasks', data=task_args) '/tasks', data=task_args)
self.list_images.invalidate(self) self.list_images.invalidate(self)
else: else:
# Clean up after ourselves. The image did not import
# and this isn't a 'just retry' error - glance didn't
# like the content. So we don't want to keep it for
# next time.
self.delete_object(container, name)
raise OpenStackCloudException( raise OpenStackCloudException(
"Image creation failed: {message}".format( "Image creation failed: {message}".format(
message=status['message']), message=status['message']),

View File

@ -360,6 +360,25 @@ class TestImage(BaseTestImage):
'Content-Type': 'Content-Type':
'application/openstack-images-v2.1-json-patch'}) 'application/openstack-images-v2.1-json-patch'})
), ),
dict(method='HEAD',
uri='{endpoint}/{container}/{object}'.format(
endpoint=endpoint, container=container_name,
object=image_name),
headers={
'X-Timestamp': '1429036140.50253',
'X-Trans-Id': 'txbbb825960a3243b49a36f-005a0dadaedfw1',
'Content-Length': '1290170880',
'Last-Modified': 'Tue, 14 Apr 2015 18:29:01 GMT',
'X-Object-Meta-X-Shade-Sha256': fakes.NO_SHA256,
'X-Object-Meta-X-Shade-Md5': fakes.NO_MD5,
'Date': 'Thu, 16 Nov 2017 15:24:30 GMT',
'Accept-Ranges': 'bytes',
'Content-Type': 'application/octet-stream',
'Etag': fakes.NO_MD5}),
dict(method='DELETE',
uri='{endpoint}/{container}/{object}'.format(
endpoint=endpoint, container=container_name,
object=image_name)),
dict(method='GET', uri='https://image.example.com/v2/images', dict(method='GET', uri='https://image.example.com/v2/images',
json=self.fake_search_return) json=self.fake_search_return)
]) ])