swiftclient对象delete-at / after问题

时间:2014-04-23 17:20:20

标签: python openstack-swift

当使用Python swiftclient模块时,我可以使用X-Delete-At / After和一个纪元的标题POST到一个对象,但是如何显示该对象的到期时间?我正在做一些测试,似乎文件总是立即过期,例如我将来的时间设定为100天:

>>> swift.put_object('container1','test_file01.txt','This is line 1 in the file test_file01.txt done at: %s' % datetime.now().strftime('%Y-%m-%d %H:%M:%S,%f'))
'4b3faf0b79d97f5e478949e7d6c4c575'
>>> swift.head_object('container1','test_file01.txt')
{'content-length': '78', 'server': 'Jetty(7.6.4.v20120524)', 'last-modified': 'Wed, 23 Apr 2014 17:09:55 GMT', 'etag': '4b3faf0b79d97f5e478949e7d6c4c575', 'x-timestamp': '1398272995', 'date': 'Wed, 23 Apr 2014 17:09:59 GMT', 'content-type': 'application/octet-stream'}
>>> swift.post_object('container1','test_file01.txt',headers={'X-Delete-At':(datetime.now(pytz.timezone('GMT')) + timedelta(days=100)).strftime('%s')})
>>> swift.head_object('container1','test_file01.txt')

Traceback (most recent call last):
  File "<pyshell#121>", line 1, in <module>
    swift.head_object('container1','test_file01.txt')
  File "/usr/local/lib/python2.7/dist-packages/swiftclient/client.py", line 1279, in head_object
    return self._retry(None, head_object, container, obj)
  File "/usr/local/lib/python2.7/dist-packages/swiftclient/client.py", line 1189, in _retry
    rv = func(self.url, self.token, *args, **kwargs)
  File "/usr/local/lib/python2.7/dist-packages/swiftclient/client.py", line 853, in head_object
    http_response_content=body)
ClientException: Object HEAD failed: http://10.249.238.135:9024:9024/v1/rjm-vnx-namespace01/container1/test_file01.txt 404 Not Found

所以它似乎立即过期了。我的问题是:

  1. 我是否正确设置了到期日期?我希望能够对现有的对象而不是在对象创建时进行,但也许我必须在创建它时才这样做???
  2. 有没有办法看到到期时间?显然,如果它没有正常工作,没有好的方法可以看到它,但如果是,head_object()是否会返回该信息?
  3. 谢谢,

    罗布

1 个答案:

答案 0 :(得分:0)

没关系,我明白了。通过设置“after”,我意识到该值显然需要以毫秒为单位。所以当我把它改成:

>>> swift.post_object('container1','test_file01.txt',headers={'X-Delete-At':int((datetime.now(pytz.timezone('GMT')) + timedelta(days=100)).strftime('%s'))*1000})
>>> swift.head_object('container1','test_file01.txt')
{'content-length': '78', 'x-delete-at':'1406932148000', 'server': 'Jetty(7.6.4.v20120524)', 'last-modified': 'Wed, 23 Apr 2014 17:29:06 GMT', 'etag': '0baf8b37f374c94e59a05a7f7b339811', 'x-timestamp': '1398274146', 'date': 'Wed, 23 Apr 2014 17:29:08 GMT', 'content-type': 'application/octet-stream'}

然后它按预期工作。

罗布