Re: [RFC PATCH 0/4] namespacefs: Proof-of-Concept
From: Steven Rostedt
Date: Thu Nov 18 2021 - 14:36:41 EST
On Thu, 18 Nov 2021 13:22:16 -0600
ebiederm@xxxxxxxxxxxx (Eric W. Biederman) wrote:
> Steven Rostedt <rostedt@xxxxxxxxxxx> writes:
> >
> I am refreshing my nack on the concept. My nack has been in place for
> good technical reasons since about 2006.
I'll admit, we are new to this, as we are now trying to add more visibility
into the workings of things like kubernetes. And having a way of knowing
what containers are running and how to monitor them is needed, and we need
to do this for all container infrastructures.
>
> I see no way forward. I do not see a compelling use case.
What do you use to debug issues in a kubernetes cluster of hundreds of
machines running thousands of containers? Currently, if something is amiss,
a node is restarted in the hopes that the issue does not appear again. But
we would like to add infrastructure that takes advantage of tracing and
profiling to be able to narrow that down. But to do so, we need to
understand what tasks belong to what containers.
>
> There have been many conversations in the past attempt to implement
> something that requires a namespace of namespaces and they have never
> gotten anywhere.
We are not asking about a "namespace" of namespaces, but a filesystem (one,
not a namespace of one), that holds the information at the system scale,
not a container view.
I would be happy to implement something that makes a container having this
file system available "special" as most containers do not need this.
>
> I see no attempt a due diligence or of actually understanding what
> hierarchy already exists in namespaces.
This is not trivial. What did we miss?
>
> I don't mean to be nasty but I do mean to be clear. Without a
> compelling new idea in this space I see no hope of an implementation.
>
> What they are attempting to do makes it impossible to migrate a set of
> process that uses this feature from one machine to another. AKA this
> would be a breaking change and a regression if merged.
The point of this is not to allow that migration. I'd be happy to add that
if a container has access to this file system, it is pinned to the system
and can not be migrated. The whole point of this file system is to monitor
all containers no the system, and it makes no sense in migrating it.
We would duplicate it over several systems, but there's no reason to move
it once it is running.
>
> The breaking and regression are caused by assigning names to namespaces
> without putting those names into a namespace of their own. That
> appears fundamental to the concept not to the implementation.
If you think this should be migrated then yes, it is broken. But we don't
want this to work across migrations. That defeats the purpose of this work.
>
> Since the concept if merged would cause a regression it qualifies for
> a nack.
>
> We can explore what problems they are trying to solve with this and
> explore other ways to solve those problems. All I saw was a comment
> about monitoring tools and wanting a global view. I did not see
> any comments about dealing with all of the reasons why a global view
> tends to be a bad idea.
If you only care about a working environment of the system that runs a set
of containers, how is that a bad idea. Again, I'm happy with implementing
something that makes having this file system prevent it from being
migrated. A pinned privileged container.
>
> I should have added that we have to some extent a way to walk through
> namespaces using ioctls on nsfs inodes.
How robust is this? And is there a library or tooling around it?
-- Steve