Merge lp:~smoser/cloud-init/trunk.improve-wait into lp:~cloud-init-dev/cloud-init/trunk

Proposed by Scott Moser
Status: Merged
Merged at revision: 1190
Proposed branch: lp:~smoser/cloud-init/trunk.improve-wait
Merge into: lp:~cloud-init-dev/cloud-init/trunk
Diff against target: 33 lines (+5/-8)
1 file modified
udev/cloud-init-wait (+5/-8)
To merge this branch: bzr merge lp:~smoser/cloud-init/trunk.improve-wait
Reviewer Review Type Date Requested Status
Dimitri John Ledkov (community) Approve
Martin Pitt (community) Approve
cloud-init Commiters Pending
Review via email: mp+290243@code.launchpad.net

Commit message

improve how cloud-init-wait waits

  since we run from a udev event, this is sufficient.
  udev settle will exit when either of
   a.) the file exists
   b.) the udev event queue has all been processed.

  Since cloud-init-wait is being run as a udev event, 'b' cannot
  be satisfied until it finishes. Thus, this essentially becomes a
  inotify based wait for the file /run/cloud-init/network-config-ready
  and no loops are needed.

To post a comment you must log in.
Revision history for this message
Martin Pitt (pitti) wrote :

This looks nice indeed, thanks!

review: Approve
Revision history for this message
Dimitri John Ledkov (xnox) :
review: Approve

Preview Diff

[H/L] Next/Prev Comment, [J/K] Next/Prev File, [N/P] Next/Prev Hunk
1=== modified file 'udev/cloud-init-wait'
2--- udev/cloud-init-wait 2016-03-21 02:31:21 +0000
3+++ udev/cloud-init-wait 2016-03-28 18:55:53 +0000
4@@ -3,16 +3,13 @@
5 CI_NET_READY="/run/cloud-init/network-config-ready"
6 LOG="/run/cloud-init/${0##*/}.log"
7 LOG_INIT=0
8+MAX_WAIT=60
9 DEBUG=0
10
11 block_until_ready() {
12- local fname="$1"
13- local naplen="$2" max="$3" n=0
14- while ! [ -f "$fname" ]; do
15- n=$(($n+1))
16- [ "$n" -ge "$max" ] && return 1
17- sleep $naplen
18- done
19+ local fname="$1" max="$2"
20+ [ -f "$fname" ] && return 0
21+ udevadm settle "--timeout=$max" "--exit-if-exists=$fname"
22 }
23
24 log() {
25@@ -56,7 +53,7 @@
26 return 0
27 fi
28
29- block_until_ready "$readyfile" .1 600 ||
30+ block_until_ready "$readyfile" "$MAX_WAIT" ||
31 { log "failed waiting for ready on $INTERFACE"; return 1; }
32
33 log "net config ready"