diff options
author | Scott Moser <smoser@ubuntu.com> | 2012-09-13 14:01:04 -0400 |
---|---|---|
committer | Scott Moser <smoser@ubuntu.com> | 2012-09-13 14:01:04 -0400 |
commit | 67bf7722398278e7089098dfd683389ef4e418c5 (patch) | |
tree | 054f5e096817580aea89ada5cc3c9bbf88f11035 | |
parent | 75bec162045856b39b483d11a0b3a7a75886efd2 (diff) | |
download | vyos-cloud-init-67bf7722398278e7089098dfd683389ef4e418c5.tar.gz vyos-cloud-init-67bf7722398278e7089098dfd683389ef4e418c5.zip |
add cloud-init-container.conf
This changes the way that we avoid cloud-init-nonet hanging in a container.
Previously, under LP: #800824 we tried 'start networking', but that caused
issues described in LP: #1031065.
Here, we emit the net-device-added for any devices that have not yet been
seen.
LP: #1031065
-rw-r--r-- | upstart/cloud-init-container.conf | 41 | ||||
-rw-r--r-- | upstart/cloud-init-nonet.conf | 2 |
2 files changed, 41 insertions, 2 deletions
diff --git a/upstart/cloud-init-container.conf b/upstart/cloud-init-container.conf new file mode 100644 index 00000000..b3123721 --- /dev/null +++ b/upstart/cloud-init-container.conf @@ -0,0 +1,41 @@ +# in a lxc container, events for network interfaces do not +# get created or may be missed. This helps cloud-init-nonet along +# by emitting those events if they have not been emitted. + +start on container +stop on static-network-up +task + +emits net-device-added + +console output + +script + # if we are inside a container, then we may have to emit the ifup + # events for 'auto' network devices. + set -f + + # from /etc/network/if-up.d/upstart + MARK_DEV_PREFIX="/run/network/ifup." + MARK_STATIC_NETWORK_EMITTED="/run/network/static-network-up-emitted" + # if the all static network interfaces are already up, nothing to do + [ -f "$MARK_STATIC_NETWORK_EMITTED" ] && exit 0 + + # get list of all 'auto' interfaces. if there are none, nothing to do. + auto_list=$(ifquery --list --allow auto 2>/dev/null) || : + [ -z "$auto_list" ] && exit 0 + set -- ${auto_list} + [ "$*" = "lo" ] && exit 0 + + to_emit="" + for iface in "$@"; do + [ "$iface" = "lo" ] && continue + # skip interfaces that are already up + [ -f "${MARK_DEV_PREFIX}${iface}" ] && continue + initctl emit --no-wait net-device-added "INTERFACE=$iface" && + emitted="${emitted} ${iface}" || : + done + + [ -z "${emitted# }" ] || + echo "${UPSTART_JOB}: emitted ifup for ${emitted# }" +end script diff --git a/upstart/cloud-init-nonet.conf b/upstart/cloud-init-nonet.conf index 7b69e584..118ffc1c 100644 --- a/upstart/cloud-init-nonet.conf +++ b/upstart/cloud-init-nonet.conf @@ -18,8 +18,6 @@ script [ -f /var/lib/cloud/instance/obj.pkl ] && exit 0 - start networking >/dev/null - short=10; long=120; sleep ${short} echo $UPSTART_JOB "waiting ${long} seconds for a network device." |