From: Reinette Chatre <reinette.chatre@intel.com>
To: Peter Newman <peternewman@google.com>, Fenghua Yu <fenghua.yu@intel.com>
Cc: Stephane Eranian <eranian@google.com>,
<linux-kernel@vger.kernel.org>,
Thomas Gleixner <tglx@linutronix.de>,
James Morse <james.morse@arm.com>,
Babu Moger <Babu.Moger@amd.com>,
"Luck, Tony" <tony.luck@intel.com>
Subject: Re: [RFD] resctrl: reassigning a running container's CTRL_MON group
Date: Fri, 7 Oct 2022 08:36:37 -0700 [thread overview]
Message-ID: <b2e020b1-f6b2-e236-a042-4eb2fd27d8b0@intel.com> (raw)
In-Reply-To: <CALPaoCj-zav4x6H3ffXo_O+RFan8Qb-uLy-DdtkaQTfuxY4a0w@mail.gmail.com>
+Tony
On 10/7/2022 3:39 AM, Peter Newman wrote:
> Hi Reinette, Fenghua,
>
> I'd like to talk about the tasks file interface in CTRL_MON and MON
> groups.
>
> For some background, we are using the memory-bandwidth monitoring and
> allocation features of resctrl to maintain QoS on external memory
> bandwidth for latency-sensitive containers to help enable batch
> containers to use up leftover CPU/memory resources on a machine. We
> also monitor the external memory bandwidth usage of all hosted
> containers to identify ones which are misusing their latency-sensitive
> CoS assignment and downgrade them to the batch CoS.
>
> The trouble is, container manager developers working with the tasks
> interface have complained that it's not usable for them because it takes
> many (or an unbounded number of) passes to move all tasks from a
> container over, as the list is always changing.
>
> Our solution for them is to remove the need for moving tasks between
> CTRL_MON groups. Because we are mainly using MB throttling to implement
> QoS, we only need two classes of service. Therefore we've modified
> resctrl to reuse existing CLOSIDs for CTRL_MON groups with identical
> configurations, allowing us to create a CTRL_MON group for every
> container. Instead of moving the tasks over, we only need to update
> their CTRL_MON group's schemata. Another benefit for us is that we do
> not need to also move all of the tasks over to a new monitoring group in
> the batch CTRL_MON group, and the usage counts remain intact.
>
> The CLOSID management rules would roughly be:
>
> 1. If an update would cause a CTRL_MON group's config to match that of
> an existing group, the CTRL_MON group's CLOSID should change to that
> of the existing group, where the definition of "match" is: all
> control values match in all domains for all resources, as well as
> the cpu masks matching.
>
> 2. If an update to a CTRL_MON group sharing a CLOSID with another group
> causes that group to no longer match any others, a new CLOSID must
> be allocated.
>
> 3. An update to a CTRL_MON group using a non-shared CLOSID which
> continues to not match any others follows the current resctrl
> behavior.
>
> Before I prepare any patches for review, I'm interested in any comments
> or suggestions on the use case and solution.
>
> Are there simpler strategies for reassigning a running container's tasks
> to a different CTRL_MON group that we should be considering first?
>
> Any concerns about the CLOSID-reusing behavior? The hope is existing
> users who aren't creating identically-configured CTRL_MON groups would
> be minimally impacted. Would it help if the proposed behavior were
> opt-in at mount-time?
>
> Thanks!
> -Peter
next prev parent reply other threads:[~2022-10-07 15:36 UTC|newest]
Thread overview: 53+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-10-07 10:39 [RFD] resctrl: reassigning a running container's CTRL_MON group Peter Newman
2022-10-07 15:36 ` Reinette Chatre [this message]
2022-10-07 15:44 ` Yu, Fenghua
2022-10-07 17:28 ` Tony Luck
2022-10-10 23:35 ` Reinette Chatre
2022-10-12 11:21 ` Peter Newman
2022-10-12 16:55 ` James Morse
2022-10-17 10:15 ` Peter Newman
2022-10-19 13:57 ` James Morse
2022-10-20 10:39 ` Peter Newman
2022-10-21 12:42 ` Peter Newman
2022-10-25 15:55 ` James Morse
2022-10-26 8:52 ` Peter Newman
2022-10-26 21:12 ` Reinette Chatre
2022-10-27 7:56 ` Peter Newman
2022-10-27 17:35 ` Reinette Chatre
2022-11-01 15:23 ` Peter Newman
2022-11-01 15:53 ` Peter Newman
2022-11-01 16:48 ` Reinette Chatre
2022-10-25 15:56 ` James Morse
2022-10-21 20:09 ` Reinette Chatre
2022-10-21 20:22 ` Luck, Tony
2022-10-21 21:34 ` Reinette Chatre
2022-11-03 17:06 ` James Morse
2022-11-08 21:28 ` Reinette Chatre
2022-11-08 21:56 ` Luck, Tony
2022-11-08 23:18 ` Reinette Chatre
2022-11-09 17:58 ` James Morse
2022-11-09 9:50 ` Peter Newman
2022-11-09 19:11 ` Reinette Chatre
2022-11-11 18:38 ` James Morse
2022-11-14 18:02 ` Reinette Chatre
2022-11-16 13:20 ` Peter Newman
2022-11-09 17:59 ` James Morse
2022-11-09 19:12 ` Reinette Chatre
2022-11-11 18:36 ` James Morse
2022-10-12 16:57 ` Yu, Fenghua
2022-10-12 17:23 ` Reinette Chatre
2022-10-14 12:56 ` James Morse
2022-10-19 9:08 ` Peter Newman
2022-10-19 13:20 ` James Morse
2022-10-19 23:54 ` Reinette Chatre
2022-10-20 8:48 ` Peter Newman
2022-10-20 19:08 ` Reinette Chatre
2022-10-21 10:09 ` Peter Newman
2022-10-25 15:56 ` James Morse
2022-10-25 15:55 ` James Morse
2022-10-26 9:36 ` Peter Newman
2022-11-03 17:06 ` James Morse
2022-11-08 21:25 ` Reinette Chatre
2022-10-07 17:57 ` Moger, Babu
2022-10-11 15:00 ` Stephane Eranian
2022-10-11 14:59 ` Stephane Eranian
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=b2e020b1-f6b2-e236-a042-4eb2fd27d8b0@intel.com \
--to=reinette.chatre@intel.com \
--cc=Babu.Moger@amd.com \
--cc=eranian@google.com \
--cc=fenghua.yu@intel.com \
--cc=james.morse@arm.com \
--cc=linux-kernel@vger.kernel.org \
--cc=peternewman@google.com \
--cc=tglx@linutronix.de \
--cc=tony.luck@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox