Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1030393AbWILXyT (ORCPT ); Tue, 12 Sep 2006 19:54:19 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1030394AbWILXyT (ORCPT ); Tue, 12 Sep 2006 19:54:19 -0400 Received: from e34.co.us.ibm.com ([32.97.110.152]:33503 "EHLO e34.co.us.ibm.com") by vger.kernel.org with ESMTP id S1030393AbWILXyS (ORCPT ); Tue, 12 Sep 2006 19:54:18 -0400 Subject: Re: [ckrm-tech] [PATCH] BC: resource beancounters (v4) (added user memory) From: Chandra Seetharaman Reply-To: sekharan@us.ibm.com To: rohitseth@google.com Cc: Rik van Riel , Srivatsa , Alan Cox , CKRM-Tech , balbir@in.ibm.com, Dave Hansen , Linux Kernel Mailing List , Andi Kleen , Christoph Hellwig , Andrey Savochkin , Matt Helsley , Hugh Dickins , Alexey Dobriyan , Kirill Korotaev , Oleg Nesterov , devel@openvz.org, Pavel Emelianov In-Reply-To: <1158019099.12947.102.camel@galaxy.corp.google.com> References: <44FD918A.7050501@sw.ru> <44FDAB81.5050608@in.ibm.com> <44FEC7E4.7030708@sw.ru> <44FF1EE4.3060005@in.ibm.com> <1157580371.31893.36.camel@linuxchandra> <45011CAC.2040502@openvz.org> <1157743424.19884.65.camel@linuxchandra> <1157751834.1214.112.camel@galaxy.corp.google.com> <1157999107.6029.7.camel@linuxchandra> <1158001831.12947.16.camel@galaxy.corp.google.com> <1158003725.6029.60.camel@linuxchandra> <1158019099.12947.102.camel@galaxy.corp.google.com> Content-Type: text/plain Organization: IBM Date: Tue, 12 Sep 2006 16:54:13 -0700 Message-Id: <1158105253.4800.20.camel@linuxchandra> Mime-Version: 1.0 X-Mailer: Evolution 2.0.4 (2.0.4-7) Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4772 Lines: 118 On Mon, 2006-09-11 at 16:58 -0700, Rohit Seth wrote: > On Mon, 2006-09-11 at 12:42 -0700, Chandra Seetharaman wrote: > > On Mon, 2006-09-11 at 12:10 -0700, Rohit Seth wrote: > > > On Mon, 2006-09-11 at 11:25 -0700, Chandra Seetharaman wrote: > > > > > There could be a default container which doesn't have any guarantee or > > > > limit. > > > > > > First, I think it is critical that we allow processes to run outside of > > > any container (unless we know for sure that the penalty of running a > > > process inside a container is very very minimal). > > > > When I meant a default container I meant a default "resource group". In > > case of container that would be the default environment. I do not see > > any additional overhead associated with it, it is only associated with > > how resource are allocated/accounted. > > > > There should be some cost when you do atomic inc/dec accounting and > locks for add/remove resources from any container (including default > resource group). No? yes, it would be there, but is not heavy, IMO. > > > > > > > And anything running outside a container should be limited by default > > > Linux settings. > > > > note that the resource available to the default RG will be (total system > > resource - allocated to RGs). > > I think it will be preferable to not change the existing behavior for > applications that are running outside any container (in your case > default resource group). hmm, when you provide QoS for a set of apps, you will affect (the resource availability of) other apps. I don't see any way around it. Any ideas ? > > > > > > > > When you create containers and assign guarantees to each of them > > > > make sure that you leave some amount of resource unassigned. > > > ^^^^^ This will force the "default" container > > > with limits (indirectly). IMO, the whole guarantee feature gets defeated > > > > You _will_ have limits for the default RG even if we don't have > > guarantees. > > > > > the moment you bring in this fuzziness. > > > > Not really. > > - Each RG will have a guarantee and limit of each resource. > > - default RG will have (system resource - sum of guarantees) > > - Every RG will be guaranteed some amount of resource to provide QoS > > - Every RG will be limited at "limit" to prevent DoS attacks. > > - Whoever doesn't care either of those set them to don't care values. > > > > For the cases that put this don't care, do you depend on existing > reclaim algorithm (for memory) in kernel? Yes. > > > > > > > > That > > > > unassigned resources can be used by the default container or can be used > > > > by containers that want more than their guarantee (and less than their > > > > limit). This is how CKRM/RG handles this issue. > > > > > > > > > > > > > > It seems that a single notion of limit should suffice, and that limit > > > should more be treated as something beyond which that resource > > > consumption in the container will be throttled/not_allowed. > > > > As I stated in an earlier email "Limit only" approach can prevent a > > system from DoS attacks (and also fits the container model nicely), > > whereas to provide QoS one would need guarantee. > > > > Without guarantee, a RG that the admin cares about can starve if > > all/most of the other RGs consume upto their limits. > > > > > > > If the limits are set appropriately so that containers total memory > consumption does not exceed the system memory then there shouldn't be > any QoS issue (to whatever extent it is applicable for specific > scenario). Then you will not be work-conserving (IOW over-committing), which is one of the main advantage of this type of feature. > > -rohit > > > ------------------------------------------------------------------------- > Using Tomcat but need to do more? Need to support web services, security? > Get stuff done quickly with pre-integrated technology to make your job easier > Download IBM WebSphere Application Server v.1.0.1 based on Apache Geronimo > http://sel.as-us.falkag.net/sel?cmd=lnk&kid=120709&bid=263057&dat=121642 > _______________________________________________ > ckrm-tech mailing list > https://lists.sourceforge.net/lists/listinfo/ckrm-tech -- ---------------------------------------------------------------------- Chandra Seetharaman | Be careful what you choose.... - sekharan@us.ibm.com | .......you may get it. ---------------------------------------------------------------------- - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/