I’ll reiterate my points from #chef:
On 27 January 2012 16:46, Hector Castro email@example.com wrote:
I’m currently in the middle of assembling a process that takes a Chef bootstrapped AMI and yields a fully functional (data as well) server. My goal is to have EBS snapshot IDs of primary EBS volumes available to the bootstrapped node in some way (data bags, node attributes) so that the data that becomes available is not stale.
The AWS cookbook has a nice LWRP for EBS that handles snapshots — but doesn’t give you a way to save its ID for later use (unlike the create action that saves volume IDs to node attributes).
Would there be any value in adding an array of snapshot IDs to the corresponding volume ID node attribute on snapshot creation? I mentioned it in #chef today and received some initial concern over having to maintain an accurate representation of available snapshots in the node attributes — a valid concern. Any other feedback or suggestions to alternate approaches are welcome.
My concerns mostly lie around using this data to make decisions on the
infrastructure. It’s not the API – it’s not the canonical source of
information, sure, you could update it when you perform a snapshot…
but what if that snapshot errors out? It’s a non blocking attribute
write, so… that just gets lost somewhere. If something else tried to
search for that snapshot id, and it had errored after the chef run had
complete… then… you would have to obviously deal with that state.
Perhaps an ohai plugin could be developed to present node attributes
on the available snapshots for all volumes attached to the current
instance – at least it would be accurate at the time of plugin
actually running, instead of having this delayed view of the API.
There are dragons here. Be super careful about any automatic recovery
system designed around EBS snapshots.