lxc_start.c revision d028235de9ec7664e1c2c904c541a447a768997a
/*
* lxc: linux Container library
*
* (C) Copyright IBM Corp. 2007, 2008
*
* Authors:
* Daniel Lezcano <daniel.lezcano at free.fr>
*
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "config.h"
#include <stdio.h>
#include <libgen.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <errno.h>
#include <fcntl.h>
#include <signal.h>
#include <lxc/lxccontainer.h>
#include "log.h"
#include "caps.h"
#include "lxc.h"
#include "conf.h"
#include "cgroup.h"
#include "utils.h"
#include "confile.h"
#include "arguments.h"
{
if (path) {
goto err;
}
if (fd >= 0)
}
if (!fullpath) {
goto err;
}
if (!*confpath) {
goto err;
}
}
err = 0;
err:
return err;
}
char *eptr;
struct lxc_container *s;
if (!s) {
return -1;
}
if (!s->may_control(s)) {
return -1;
}
if (pid < 1) {
return -1;
}
}
return -1;
}
return pid;
}
int fd;
char path[MAXPATHLEN];
if (fd < 0) {
return -1;
}
return fd;
}
{
switch (c) {
}
return 0;
}
static const struct option my_longopts[] = {
};
static struct lxc_arguments my_args = {
.progname = "lxc-start",
.help = "\
--name=NAME -- COMMAND\n\
\n\
lxc-start start COMMAND in specified container NAME\n\
\n\
Options :\n\
-n, --name=NAME NAME of the container\n\
-d, --daemon Daemonize the container (default)\n\
-p, --pidfile=FILE Create a file with the process id\n\
-f, --rcfile=FILE Load configuration file FILE\n\
-c, --console=FILE Use specified FILE for the container console\n\
-L, --console-log=FILE Log container console output to FILE\n\
-C, --close-all-fds If any fds are inherited, close them\n\
If not specified, exit with failure instead\n\
Note: --daemon implies --close-all-fds\n\
-s, --define KEY=VAL Assign VAL to configuration variable KEY\n\
--share-[net|ipc|uts]=NAME Share a namespace with another container or pid\n\
",
.options = my_longopts,
.daemonize = 1,
};
{
int err = 1;
char *const *args;
char *const default_args[] = {
NULL,
};
struct lxc_container *c;
if (lxc_caps_init())
return err;
return err;
args = default_args;
else
return err;
/*
* rcfile possibilities:
* 1. rcfile from random path specified in cli option
* 3. rcfile not specified and does not exist.
*/
/* rcfile is specified in the cli option */
if (!c) {
ERROR("Failed to create lxc_container");
return err;
}
c->clear_config(c);
if (!c->load_config(c, rcfile)) {
ERROR("Failed to load rcfile");
return err;
}
} else {
int rc;
if (rc == -1) {
SYSERROR("failed to allocate memory");
return err;
}
/* container configuration does not exist */
}
if (!c) {
ERROR("Failed to create lxc_container");
return err;
}
}
if (c->is_running(c)) {
ERROR("Container is already running.");
err = 0;
goto out;
}
/*
* We should use set_config_item() over &defines, which would handle
* unset c->lxc_conf for us and let us not use lxc_config_define_load()
*/
if (!c->lxc_conf)
c->lxc_conf = lxc_conf_init();
goto out;
goto out;
}
goto out;
}
goto out;
}
goto out;
}
}
int i;
for (i = 0; i < LXC_NS_MAX; i++) {
continue;
if (pid < 1)
goto out;
if (fd < 0)
goto out;
}
c->want_daemonize(c, false);
}
if (my_args.close_all_fds)
c->want_close_all_fds(c, true);
if (args == default_args)
else
if (err) {
ERROR("The container failed to start.");
ERROR("To get more details, run the container in foreground mode.");
ERROR("Additional information can be obtained by setting the "
"--logfile and --logpriority options.");
return err;
}
out:
return err;
}