Commit 3114c982 by Natanael Copa Committed by Stéphane Graber

lxc-start: add option -p, --pidfile=FILE

Add option to create a pidfile for lxc-start. This is helpful for init scripts and process monitors when running as daemon. Signed-off-by: 's avatarNatanael Copa <ncopa@alpinelinux.org> Acked-by: 's avatarSerge E. Hallyn <serge.hallyn@ubuntu.com> Acked-by: 's avatarStéphane Graber <stgraber@ubuntu.com>
parent f6a8db2d
...@@ -53,6 +53,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ...@@ -53,6 +53,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
<arg choice="opt">-f <replaceable>config_file</replaceable></arg> <arg choice="opt">-f <replaceable>config_file</replaceable></arg>
<arg choice="opt">-c <replaceable>console_file</replaceable></arg> <arg choice="opt">-c <replaceable>console_file</replaceable></arg>
<arg choice="opt">-d</arg> <arg choice="opt">-d</arg>
<arg choice="opt">-p <replaceable>pid_file</replaceable></arg>
<arg choice="opt">-s KEY=VAL</arg> <arg choice="opt">-s KEY=VAL</arg>
<arg choice="opt">-C</arg> <arg choice="opt">-C</arg>
<arg choice="opt">command</arg> <arg choice="opt">command</arg>
...@@ -109,6 +110,17 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ...@@ -109,6 +110,17 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
<varlistentry> <varlistentry>
<term> <term>
<option>-p, --pidfile <replaceable>pid_file</replaceable></option>
</term>
<listitem>
<para>
Create a file with the process id.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term>
<option>-f, --rcfile <replaceable>config_file</replaceable></option> <option>-f, --rcfile <replaceable>config_file</replaceable></option>
</term> </term>
<listitem> <listitem>
......
...@@ -45,6 +45,7 @@ struct lxc_arguments { ...@@ -45,6 +45,7 @@ struct lxc_arguments {
int daemonize; int daemonize;
const char *rcfile; const char *rcfile;
const char *console; const char *console;
const char *pidfile;
/* for lxc-checkpoint/restart */ /* for lxc-checkpoint/restart */
const char *statefile; const char *statefile;
......
...@@ -62,6 +62,7 @@ static int my_parser(struct lxc_arguments* args, int c, char* arg) ...@@ -62,6 +62,7 @@ static int my_parser(struct lxc_arguments* args, int c, char* arg)
case 'f': args->rcfile = arg; break; case 'f': args->rcfile = arg; break;
case 'C': args->close_all_fds = 1; break; case 'C': args->close_all_fds = 1; break;
case 's': return lxc_config_define_add(&defines, arg); case 's': return lxc_config_define_add(&defines, arg);
case 'p': args->pidfile = arg; break;
} }
return 0; return 0;
} }
...@@ -72,6 +73,7 @@ static const struct option my_longopts[] = { ...@@ -72,6 +73,7 @@ static const struct option my_longopts[] = {
{"define", required_argument, 0, 's'}, {"define", required_argument, 0, 's'},
{"console", required_argument, 0, 'c'}, {"console", required_argument, 0, 'c'},
{"close-all-fds", no_argument, 0, 'C'}, {"close-all-fds", no_argument, 0, 'C'},
{"pidfile", required_argument, 0, 'p'},
LXC_COMMON_OPTIONS LXC_COMMON_OPTIONS
}; };
...@@ -85,6 +87,7 @@ lxc-start start COMMAND in specified container NAME\n\ ...@@ -85,6 +87,7 @@ lxc-start start COMMAND in specified container NAME\n\
Options :\n\ Options :\n\
-n, --name=NAME NAME for name of the container\n\ -n, --name=NAME NAME for name of the container\n\
-d, --daemon daemonize the container\n\ -d, --daemon daemonize the container\n\
-p, --pidfile=FILE Create a file with the process id\n\
-f, --rcfile=FILE Load configuration file FILE\n\ -f, --rcfile=FILE Load configuration file FILE\n\
-c, --console=FILE Set the file output for the container console\n\ -c, --console=FILE Set the file output for the container console\n\
-C, --close-all-fds If any fds are inherited, close them\n\ -C, --close-all-fds If any fds are inherited, close them\n\
...@@ -95,6 +98,7 @@ Options :\n\ ...@@ -95,6 +98,7 @@ Options :\n\
.parser = my_parser, .parser = my_parser,
.checker = NULL, .checker = NULL,
.daemonize = 0, .daemonize = 0,
.pidfile = NULL,
}; };
int main(int argc, char *argv[]) int main(int argc, char *argv[])
...@@ -107,6 +111,7 @@ int main(int argc, char *argv[]) ...@@ -107,6 +111,7 @@ int main(int argc, char *argv[])
"/sbin/init", "/sbin/init",
'\0', '\0',
}; };
FILE *pid_fp = NULL;
lxc_list_init(&defines); lxc_list_init(&defines);
...@@ -199,6 +204,14 @@ int main(int argc, char *argv[]) ...@@ -199,6 +204,14 @@ int main(int argc, char *argv[])
free(console); free(console);
} }
if (my_args.pidfile != NULL) {
pid_fp = fopen(my_args.pidfile, "w");
if (pid_fp == NULL) {
SYSERROR("failed to create '%s'", my_args.name);
return err;
}
}
if (my_args.daemonize) { if (my_args.daemonize) {
/* do an early check for needed privs, since otherwise the /* do an early check for needed privs, since otherwise the
* user won't see the error */ * user won't see the error */
...@@ -214,6 +227,14 @@ int main(int argc, char *argv[]) ...@@ -214,6 +227,14 @@ int main(int argc, char *argv[])
} }
} }
if (pid_fp != NULL) {
if (fprintf(pid_fp, "%d\n", getpid()) < 0) {
SYSERROR("failed to write '%s'", my_args.pidfile);
return err;
}
fclose(pid_fp);
}
if (my_args.close_all_fds) if (my_args.close_all_fds)
conf->close_all_fds = 1; conf->close_all_fds = 1;
...@@ -230,6 +251,9 @@ int main(int argc, char *argv[]) ...@@ -230,6 +251,9 @@ int main(int argc, char *argv[])
err = -1; err = -1;
} }
if (my_args.pidfile)
unlink(my_args.pidfile);
return err; return err;
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment