Always update cache for HTTP images if Last Modified is unknown
Currently we default to assuming the cache is up-to-date. This is likely wrong. Normal web servers provide Last Modified for files they serve. If it is absent, chances are high the image is served by some sort of a dynamic service, which may modify the URL on fly. In any case, always updating the image is a safer choice. Change-Id: I0548db14a97638d26ebb687e8f47f1b295d1f774
This commit is contained in:
parent
a71ed5de26
commit
94a1560d31
@ -48,6 +48,9 @@ There are however some limitations for different hardware interfaces:
|
|||||||
modification time, Ironic will re-download the content. For "file://"
|
modification time, Ironic will re-download the content. For "file://"
|
||||||
images, the file system modification time is used.
|
images, the file system modification time is used.
|
||||||
|
|
||||||
|
If the HTTP server does not provide the last modification date and time,
|
||||||
|
the image will be redownloaded every time it is used.
|
||||||
|
|
||||||
.. _hashlib: https://docs.python.org/3/library/hashlib.html
|
.. _hashlib: https://docs.python.org/3/library/hashlib.html
|
||||||
|
|
||||||
Enrolling nodes
|
Enrolling nodes
|
||||||
|
@ -414,20 +414,22 @@ def _delete_master_path_if_stale(master_path, href, ctx):
|
|||||||
img_mtime = img_service.show(href).get('updated_at')
|
img_mtime = img_service.show(href).get('updated_at')
|
||||||
if not img_mtime:
|
if not img_mtime:
|
||||||
# This means that href is not a glance image and doesn't have an
|
# This means that href is not a glance image and doesn't have an
|
||||||
# updated_at attribute
|
# updated_at attribute. To play on the safe side, redownload the
|
||||||
|
# master copy of the image.
|
||||||
LOG.warning("Image service couldn't determine last "
|
LOG.warning("Image service couldn't determine last "
|
||||||
"modification time of %(href)s, considering "
|
"modification time of %(href)s, updating "
|
||||||
"cached image up to date.", {'href': href})
|
"the cached copy %(cached_file)s.",
|
||||||
return True
|
{'href': href, 'cached_file': master_path})
|
||||||
master_mtime = utils.unix_file_modification_datetime(master_path)
|
else:
|
||||||
if img_mtime <= master_mtime:
|
master_mtime = utils.unix_file_modification_datetime(master_path)
|
||||||
return True
|
if img_mtime <= master_mtime:
|
||||||
# Delete image from cache as it is outdated
|
return True
|
||||||
LOG.info('Image %(href)s was last modified at %(remote_time)s. '
|
# Delete image from cache as it is outdated
|
||||||
'Deleting the cached copy "%(cached_file)s since it was '
|
LOG.info('Image %(href)s was last modified at %(remote_time)s. '
|
||||||
'last modified at %(local_time)s and may be outdated.',
|
'Deleting the cached copy "%(cached_file)s since it was '
|
||||||
{'href': href, 'remote_time': img_mtime,
|
'last modified at %(local_time)s and may be outdated.',
|
||||||
'local_time': master_mtime, 'cached_file': master_path})
|
{'href': href, 'remote_time': img_mtime,
|
||||||
|
'local_time': master_mtime, 'cached_file': master_path})
|
||||||
|
|
||||||
os.unlink(master_path)
|
os.unlink(master_path)
|
||||||
return False
|
return False
|
||||||
|
@ -298,8 +298,8 @@ class TestUpdateImages(base.TestCase):
|
|||||||
res = image_cache._delete_master_path_if_stale(self.master_path, href,
|
res = image_cache._delete_master_path_if_stale(self.master_path, href,
|
||||||
None)
|
None)
|
||||||
mock_gis.assert_called_once_with(href, context=None)
|
mock_gis.assert_called_once_with(href, context=None)
|
||||||
self.assertFalse(mock_unlink.called)
|
mock_unlink.assert_called_once_with(self.master_path)
|
||||||
self.assertTrue(res)
|
self.assertFalse(res)
|
||||||
|
|
||||||
@mock.patch.object(image_service, 'get_image_service', autospec=True)
|
@mock.patch.object(image_service, 'get_image_service', autospec=True)
|
||||||
def test__delete_master_path_if_stale_master_up_to_date(self, mock_gis,
|
def test__delete_master_path_if_stale_master_up_to_date(self, mock_gis,
|
||||||
|
8
releasenotes/notes/image-cache-4082178dabd64249.yaml
Normal file
8
releasenotes/notes/image-cache-4082178dabd64249.yaml
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
When an ``http(s)://`` image is used, the cached copy of the image will always
|
||||||
|
be updated if the HTTP server does not provide the last modification date
|
||||||
|
and time. Previously the cached image would be considered up-to-date, which
|
||||||
|
could cause invalid behavior if the image is generated on fly or was modified
|
||||||
|
while being served.
|
Loading…
x
Reference in New Issue
Block a user