On Thu, Jul 20, 2023 at 3:31 PM Tejun Heo <tj@xxxxxxxxxx> wrote: > > Hello, > > On Thu, Jul 20, 2023 at 03:23:59PM -0700, Yosry Ahmed wrote: > > > On its own, AFAICS, I'm not sure the scope of problems it can actually solve > > > is justifiably greater than what can be achieved with simple nesting. > > > > In our use case nesting is not a viable option. As I said, in a large > > fleet where a lot of different workloads are dynamically being > > scheduled on different machines, and where there is no way of knowing > > what resources are being shared among what workloads, and even if we > > do, it wouldn't be constant, it's very difficult to construct the > > hierarchy with nesting to keep the resources confined. > > Hmm... so, usually, the problems we see are resources that are persistent > across different instances of the same application as they may want to share > large chunks of memory like on-memory cache. I get that machines get > different dynamic jobs but unrelated jobs usually don't share huge amount of I am digging deeper to get more information for you. One thing I know now is that different instances of the same job are contained within a common parent, and we even use our previously proposed memcg= mount option for tmpfs to charge their shared resources to a common parent. So restarting tasks is not the problem we are seeing. > memory at least in our case. The sharing across them comes down to things > like some common library pages which don't really account for much these > days. Keep in mind that even a single page charged to a memcg and used by another memcg is sufficient to result in a zombie memcg. > > > Keep in mind that the environment is dynamic, workloads are constantly > > coming and going. Even if find the perfect nesting to appropriately > > scope resources, some rescheduling may render the hierarchy obsolete > > and require us to start over. > > Can you please go into more details on how much memory is shared for what > across unrelated dynamic workloads? That sounds different from other use > cases. I am trying to collect more information from our fleet, but the application restarting in a different cgroup is not what is happening in our case. It is not easy to find out exactly what is going on on machines and where the memory is coming from due to the indeterministic nature of charging. The goal of this proposal is to let the kernel handle leftover memory in zombie memcgs because it is not always obvious to userspace what's going on (like it's not obvious to me now where exactly is the sharing happening :) ). One thing to note is that in some cases, maybe a userspace bug or failed cleanup is a reason for the zombie memcgs. Ideally, this wouldn't happen, but it would be nice to have a fallback mechanism in the kernel if it does. > > Thanks. > > -- > tejun