From b486346aa2fad7de06c491755b9b50c58c27a017 Mon Sep 17 00:00:00 2001 From: Jan Kiszka Date: Thu, 9 Aug 2012 17:54:48 -0500 Subject: [PATCH] lxc-wait: Add timeout option Allow to specify a timeout for waiting on state changes via lxc-wait. Helpful for scripts that need to handle errors or excessive delays in state changing procedures. Signed-off-by: Jan Kiszka Signed-off-by: Serge Hallyn --- doc/lxc-wait.sgml.in | 11 +++++++++++ src/lxc/arguments.h | 1 + src/lxc/lxc_wait.c | 16 +++++++++++++++- 3 files changed, 27 insertions(+), 1 deletion(-) diff --git a/doc/lxc-wait.sgml.in b/doc/lxc-wait.sgml.in index 4160e3812..61bff8bdf 100644 --- a/doc/lxc-wait.sgml.in +++ b/doc/lxc-wait.sgml.in @@ -79,6 +79,17 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + + + + + + + Wait timeout seconds for desired state to be reached. + + + + diff --git a/src/lxc/arguments.h b/src/lxc/arguments.h index 40f0d6c1b..3c9d28fd7 100644 --- a/src/lxc/arguments.h +++ b/src/lxc/arguments.h @@ -57,6 +57,7 @@ struct lxc_arguments { /* for lxc-wait */ char *states; + long timeout; /* close fds from parent? */ int close_all_fds; diff --git a/src/lxc/lxc_wait.c b/src/lxc/lxc_wait.c index a58e0c87c..d7a69bcf9 100644 --- a/src/lxc/lxc_wait.c +++ b/src/lxc/lxc_wait.c @@ -24,6 +24,8 @@ #include #include #include +#include +#include #include #include @@ -46,12 +48,14 @@ static int my_parser(struct lxc_arguments* args, int c, char* arg) { switch (c) { case 's': args->states = optarg; break; + case 't': args->timeout = atol(optarg); break; } return 0; } static const struct option my_longopts[] = { {"state", required_argument, 0, 's'}, + {"timeout", required_argument, 0, 't'}, LXC_COMMON_OPTIONS }; @@ -66,7 +70,8 @@ Options :\n\ -n, --name=NAME NAME for name of the container\n\ -s, --state=STATE ORed states to wait for\n\ STOPPED, STARTING, RUNNING, STOPPING,\n\ - ABORTING, FREEZING, FROZEN\n", + ABORTING, FREEZING, FROZEN\n\ + -t, --timeout=TMO Seconds to wait for state changes\n", .options = my_longopts, .parser = my_parser, .checker = my_checker, @@ -91,6 +96,11 @@ static int fillwaitedstates(char *strstates, int *states) return 0; } +static void timeout_handler(int signal) +{ + exit(-1); +} + int main(int argc, char *argv[]) { struct lxc_msg msg; @@ -124,6 +134,9 @@ int main(int argc, char *argv[]) goto out_close; } + signal(SIGALRM, timeout_handler); + alarm(my_args.timeout); + for (;;) { if (lxc_monitor_read(fd, &msg) < 0) goto out_close; @@ -140,6 +153,7 @@ int main(int argc, char *argv[]) } if (s[msg.value]) { + alarm(0); ret = 0; goto out_close; }