[lxc-devel] [PATCH] Ignore trailing /init.scope in init cgroups
Stéphane Graber
stgraber at ubuntu.com
Thu Oct 29 21:51:31 UTC 2015
On Thu, Oct 15, 2015 at 06:56:17PM +0000, Serge Hallyn wrote:
> The lxc monitor does not store the container's cgroups, rather it
> recalculates them whenever needed.
>
> Systemd moves itself into a /init.scope cgroup for the systemd
> controller.
>
> It might be worth changing that (by storing all cgroup info in the
> lxc_handler), but for now go the hacky route and chop off any
> trailing /init.scope.
>
> I definately thinkg we want to switch to storing as that will be
> more bullet-proof, but for now we need a quick backportable fix
> for systemd 226 guests.
>
> Signed-off-by: Serge Hallyn <serge.hallyn at ubuntu.com>
Acked-by: Stéphane Graber <stgraber at ubuntu.com>
> ---
> src/lxc/cgfs.c | 1 +
> src/lxc/cgmanager.c | 1 +
> src/lxc/cgroup.c | 14 ++++++++++++++
> src/lxc/cgroup.h | 2 ++
> 4 files changed, 18 insertions(+)
>
> diff --git a/src/lxc/cgfs.c b/src/lxc/cgfs.c
> index df2e6b2..d65f2d7 100644
> --- a/src/lxc/cgfs.c
> +++ b/src/lxc/cgfs.c
> @@ -1220,6 +1220,7 @@ static char *lxc_cgroup_get_hierarchy_path_data(const char *subsystem, struct cg
> info = find_info_for_subsystem(info, subsystem);
> if (!info)
> return NULL;
> + prune_init_scope(info->cgroup_path);
> return info->cgroup_path;
> }
>
> diff --git a/src/lxc/cgmanager.c b/src/lxc/cgmanager.c
> index a677c22..f868903 100644
> --- a/src/lxc/cgmanager.c
> +++ b/src/lxc/cgmanager.c
> @@ -776,6 +776,7 @@ static char *try_get_abs_cgroup(const char *name, const char *lxcpath,
> nerr = nih_error_get();
> nih_free(nerr);
> }
> + prune_init_scope(cgroup);
> return cgroup;
> }
>
> diff --git a/src/lxc/cgroup.c b/src/lxc/cgroup.c
> index 2362ad8..b1c764f 100644
> --- a/src/lxc/cgroup.c
> +++ b/src/lxc/cgroup.c
> @@ -194,3 +194,17 @@ cgroup_driver_t cgroup_driver(void)
> {
> return ops->driver;
> }
> +
> +#define INIT_SCOPE "/init.scope"
> +void prune_init_scope(char *cg)
> +{
> + char *point = cg + strlen(cg) - strlen(INIT_SCOPE);
> + if (point < cg)
> + return;
> + if (strcmp(point, INIT_SCOPE) == 0) {
> + if (point == cg)
> + *(point+1) = '\0';
> + else
> + *point = '\0';
> + }
> +}
> diff --git a/src/lxc/cgroup.h b/src/lxc/cgroup.h
> index 6706939..7704c04 100644
> --- a/src/lxc/cgroup.h
> +++ b/src/lxc/cgroup.h
> @@ -80,4 +80,6 @@ extern bool cgroup_unfreeze(struct lxc_handler *handler);
> extern void cgroup_disconnect(void);
> extern cgroup_driver_t cgroup_driver(void);
>
> +extern void prune_init_scope(char *cg);
> +
> #endif
> --
> 2.5.0
>
> _______________________________________________
> lxc-devel mailing list
> lxc-devel at lists.linuxcontainers.org
> http://lists.linuxcontainers.org/listinfo/lxc-devel
--
Stéphane Graber
Ubuntu developer
http://www.ubuntu.com
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: Digital signature
URL: <http://lists.linuxcontainers.org/pipermail/lxc-devel/attachments/20151029/6fa7c1c3/attachment.sig>
More information about the lxc-devel
mailing list