我已经阅读了关于“describe_cluster_snapshots”的解释......
它有一个选项 start_time 和 end_time 但无法对其进行排序。如何使用 boto 获取最新快照的 ID?
这是我尝试过的,但它似乎没有返回最后的快照。
mysnap=conn.describe_cluster_snapshots()
mysnapidentifier=mysnap['DescribeClusterSnapshotsResponse']['DescribeClusterSnapshotsResult']['Snapshots'][-1]['SnapshotIdentifier']
最佳答案
无法在服务器端完成排序,因此您必须在客户端进行排序。首先,从响应数据中提取快照数据列表:
response = conn.describe_cluster_snapshots()
snapshots = response['DescribeClusterSnapshotsResponse']['DescribeClusterSnapshotsResult']['Snapshots']
snapshots
变量现在应该是一个字典列表,其中每个字典代表一个快照。这些词典中的每一个都有一个名为 SnapshotCreateTime
的键,您希望按该值对列表进行排序。你可以这样做:
snapshots.sort(key=lambda d: d['SnapshotCreateTime'])
这会进行就地排序,因此您的列表现在将被修改为所有快照都按该键的升序排列。您现在可以只获取列表中的最后一项:
mysnapidentifier = snapshots[-1]['SnapshotIdentifier']
我不使用 Redshift,所以我没有实时数据来测试它,但我相信它会给你想要的东西。
关于boto - 使用 boto 查找最后一个快照,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19379987/