Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S936905AbdIZLA2 (ORCPT ); Tue, 26 Sep 2017 07:00:28 -0400 Received: from mx0a-00082601.pphosted.com ([67.231.145.42]:58260 "EHLO mx0a-00082601.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935241AbdIZLAP (ORCPT ); Tue, 26 Sep 2017 07:00:15 -0400 Date: Tue, 26 Sep 2017 11:59:25 +0100 From: Roman Gushchin To: Michal Hocko CC: Johannes Weiner , Tejun Heo , , David Rientjes , , Vladimir Davydov , Tetsuo Handa , Andrew Morton , , , Subject: Re: [v8 0/4] cgroup-aware OOM killer Message-ID: <20170926105925.GA23139@castle.dhcp.TheFacebook.com> References: <20170914134014.wqemev2kgychv7m5@dhcp22.suse.cz> <20170914160548.GA30441@castle> <20170915105826.hq5afcu2ij7hevb4@dhcp22.suse.cz> <20170915152301.GA29379@castle> <20170918061405.pcrf5vauvul4c2nr@dhcp22.suse.cz> <20170920215341.GA5382@castle> <20170925122400.4e7jh5zmuzvbggpe@dhcp22.suse.cz> <20170925170004.GA22704@cmpxchg.org> <20170925181533.GA15918@castle> <20170925202442.lmcmvqwy2jj2tr5h@dhcp22.suse.cz> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Disposition: inline In-Reply-To: <20170925202442.lmcmvqwy2jj2tr5h@dhcp22.suse.cz> User-Agent: Mutt/1.9.0 (2017-09-02) X-Originating-IP: [2620:10d:c092:200::1:b331] X-ClientProxiedBy: HE1PR05CA0163.eurprd05.prod.outlook.com (2603:10a6:3:f8::11) To CO1PR15MB1078.namprd15.prod.outlook.com (2a01:111:e400:7b66::8) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: e4ceef0b-3fe4-4939-fdbb-08d504cdaf80 X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:(22001)(2017030254152)(2017052603199)(201703131423075)(201703031133081)(201702281549075);SRVR:CO1PR15MB1078; X-Microsoft-Exchange-Diagnostics: 1;CO1PR15MB1078;3:STGAZLPGYcDIx9qsyCrZP2EHZ7W+OhhuCAjyIElzKpNvWn37HW5BUyDM4t4oNrF8DzRqPU2TDGASCrWZoSFLtE2jKwtKL81t30fI5yVUlp6bQfZa6AZMz1+f1i3bgmuB6xg3h+8GQBZNZgS88BOKjmf0VsCk4OT/E+SfcPbJuegNprWU9dVcVXV/7X6PhOHRozds43L0+s8KSMmpoUP5F4LzKiwXKZX7ZPWL0XoJ/HLa4hoY9S/Yfc3fcF+Pwli9;25:mKkrhoxW5Plxq5ZqO34qjAHdN5HLPChz1EbBQs42M7u8R9rbhpVJbvTTMpQW/7foDhvouRiYoSgw00IK4aX3RmAIIJ+e3mn6GIr0EN2QifLiChFVOVMAPOXXSbqpXHcqvWUNUbYMMRF5j3UuHZzfR4kmFNFF0oj50MgfbqigFC2A3P2YkeIfN9nuGjEXVJcl6TR6mL6Blchn52LyrPOemk8eVasKzM8hHNVZOM78MdG2X+YLaadLWdis5BsesM2UVFmCcOcgVCP+2mshx4o/C1h6KSkaaIjxGee5fJ3kMzdl1SvAR0XNSzApyP+4lO/geJS5pZfWLQ4Q7LzlxHJsAQ==;31:yoNwZMhhMw8LoVqtZPNIjzHM9NgNt9tkx80u/ULD9/cJUH3Rx+w0+V6WFVQo/e/nR4X63FqPRXoKTPJMHaFuyZ795VOtRM31ib9/37ndZ5D0vLc8SAC3jSwEdP+ufx0RRZKbfa65DK6cY8/g644teFDhEeb4brm1pihZiLAgKTakvZOY6CX1F00vTJQyESpEJdpggCeIkrg5wYvmKIWfQR6djeWyBNJ+no6o3GYxSd4= X-MS-TrafficTypeDiagnostic: CO1PR15MB1078: X-Microsoft-Exchange-Diagnostics: 1;CO1PR15MB1078;20:n/Bogzm9x9J4fAncMLrcmq+Pv02LHuCqsxx3gBCbFMF23pjrm5Ef6dvm7Wj1RIk2QIqqUnA8mykioAVlrthvwFQWkq40HlNrbvm+pFokmVyjHlaOdkh7xsrkhZyjTfuGWoVrHqiAhVeLPUaJmQITsTcdBJEK8BPO0olEMeRzYu6p37CsagTTZkMAFB5/+Bv9gsbj8KYT90NHgm53aVhscjZffxAWzPqR5CjDy11Z7X4cMFmXdasLWLUDkSvdCeCYRBUmjM7SC6JYWznPNxd1M/cnkDtwdg08FbyV0mGy09S9T3Q5Dadz517Q++5qE45JThD24dyC1f1uotbbnyDPITwUe9tN/TAIOMdh8sPZe59H86C7+1mFsp4flG79fClTBBHblFw8QoMTn3hi8x5jxD/p4RnIpkHZ6eaLyiOaZUM2IT49DOSDaS4BhkuH1IuuFr/wNRAlt2SS8mnUO+Xex+0cxbaB/52XvwUIuE6EswepTqKgUXfhfg6pHqlv1c7B;4:aQjs2T1E+f0/oHE8fmg2bIPjsB/gGhnuCtAYk6a34cFQHZS1pHU6I2nDCqkMZr7C51kogh3MkLtGm3plyevC3tWdRssY4hbrusdzsJtr5erfXlHL/8cYsesoGNyfwxM+JNYIuHk7ePf/RhLZEduQtPM7z3ilmT43gD4/4MNUPAOetECILDbmucegagn+ujmBa+41Am7pudo9hFpnLDgzD9mkDZniwY7If1rM76ginwn2OrB4XJZ6BTkL21n8w9wu X-Exchange-Antispam-Report-Test: UriScan:; X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6040450)(2401047)(8121501046)(5005006)(3002001)(93006095)(93001095)(10201501046)(100000703101)(100105400095)(6041248)(20161123560025)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(20161123555025)(20161123558100)(20161123562025)(20161123564025)(6072148)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095);SRVR:CO1PR15MB1078;BCL:0;PCL:0;RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095);SRVR:CO1PR15MB1078; X-Forefront-PRVS: 0442E569BC X-Forefront-Antispam-Report: SFV:NSPM;SFS:(10019020)(6009001)(346002)(376002)(24454002)(189002)(199003)(377424004)(51444003)(2950100002)(86362001)(229853002)(189998001)(25786009)(106356001)(9686003)(316002)(83506001)(33656002)(8676002)(93886005)(53936002)(6506006)(55016002)(6916009)(4326008)(81156014)(305945005)(478600001)(101416001)(23726003)(7736002)(5660300001)(2906002)(7416002)(47776003)(54906003)(68736007)(16586007)(6116002)(50466002)(105586002)(58126008)(6246003)(8936002)(1076002)(97736004)(6666003)(76176999)(54356999)(39060400002)(50986999)(81166006)(18370500001)(42262002);DIR:OUT;SFP:1102;SCL:1;SRVR:CO1PR15MB1078;H:castle.dhcp.TheFacebook.com;FPR:;SPF:None;PTR:InfoNoRecords;MX:1;A:1;LANG:en; X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1;CO1PR15MB1078;23:gk2wl5BlV4VIMVmvg0tl7TK0XPDC2cCAFM1dJyqvk?= =?us-ascii?Q?5SrJDHp2kH4ofObudVxow9SrGGb5OnA+FRg2iRemL8rXapp6zuIP+ua4RWI5?= =?us-ascii?Q?9wM9eiDwWBIqQIcAimCALDa/iowaNkfHhxFzu2x7cEYAt0gcUoxbyRACXHGl?= =?us-ascii?Q?HDzy+FgGpcOsUBUj57uuXisitdKHLa/hc7CJecubqtOWRDBiTbYNTjYW5o6G?= =?us-ascii?Q?vl1xxsUcLjatTY18woeSGoA3gX5c1S7UD6xVn2D+e+4Y0MO67ogXvN52Q0CF?= =?us-ascii?Q?kiaKqQsyYj4tPm0acqg4WGZVWBzxx40MyadHnXw1ZYysle+QKG14KW3tOY/P?= =?us-ascii?Q?1HysaMrhExE+azswy8i13ObUQVGM9A+Jg94Q7ECX/I5PMgM8Sxv+Vv8HU55R?= =?us-ascii?Q?Y4QcgZ6BcGUh3esA7hZzBh50tW1dDCCxaAnzUyhKf6ESwBaJtylvjqFrV7hO?= =?us-ascii?Q?LMFen/BLwd/uGcV1jVHDL0VzU2iKM9kArBC7Qd+q2uQH7kr5226q50kccAP0?= =?us-ascii?Q?gA52oqKqnG5pQ62nrCwH7mhfYpNoXYmU2GvnrQUoN8tSWNboVpki8wF0kApj?= =?us-ascii?Q?1C99p/D9W0qEvvDFwrZgUPteq1hbO7IAep0cHY56sMchASo4lzrRzcmgUpyE?= =?us-ascii?Q?qMmKD5beeGr0aQ2Vkldx7JcLVBQ1oRe4rSHuzTBREbKDBCJgoRPCB3QcKzH4?= =?us-ascii?Q?5rMsGvIIG6w7bFkHDJkXUq7/b5IO/vQBP7/2hkyUpXdfncgbmgAHxdEratee?= =?us-ascii?Q?ns9vaSbiPKdAB+7ULzV2QjGXUvF3GphwFAjZU84Kru9VmUehKzNWAikowwKP?= =?us-ascii?Q?LSxnDDfxW+qqtdMFeXlQkpS4Z5fsjY3H1Aflacgr7cgbR+PFcZH8fVVIJ0IQ?= =?us-ascii?Q?bqBynNsF51H8HfV/SgNMBNUF/QOifQKZ/Pb7T3O7xDGdYVHTyXf/3MHoHsR+?= =?us-ascii?Q?hczEVVJVVBM7N7aD7UYvEyo0ggCpqQde7Axky0+W34E5sUqDCIhUqfNytnk1?= =?us-ascii?Q?BqXM/jZpDbIFN74Ar+X7qikxfs6uOSmUjV1q2Ig7HSvYU3wvWf08S4PS/UN1?= =?us-ascii?Q?mB4rxMgaTeyfVSGVCqsRLKJT3klY/JQeCBz7bhteVWvmMeE5yOBeEDLZqwZO?= =?us-ascii?Q?lH8ebKZCN9TAPx1J2Cp1oOm2EC2skFVX6YDqQt9ZcsrFfTkkBapu0/UlhqCF?= =?us-ascii?Q?+Vhd3oOPbgABlbxvkOBUyCDOFTmOCsz2ici5IJHnxISDf3Btw51uk6SRcBwj?= =?us-ascii?Q?6sC8qp2srjEfxhriaQ=3D?= X-Microsoft-Exchange-Diagnostics: 1;CO1PR15MB1078;6:GW5ZQRXJcyT2iGj0uBVxwOqk/+1rPEohobf26aapbt/thrhLroV09O42uLd/tOLU6R3KuLheo5U71VGnrE+1xZr/Vn9bmDBrtTZ2fGuhb5r4skuT8hjkzgRt81BE+ZyT46fnvljZ5dJfbCAQWLR8csl4qjF2IJyaC6dudDI7jhcABgVxHt274vJczQCFvaLjvbRDO8OdH7n2IesEcMPsQTgaTIK7zm4r+JC3scuHWsCm1G6piis+WZSjYakanRcXi54KzDYZ+qe4Hle9TklLwJfxvM1OdvFXOG35V25ZaZIlq5eY/yVr8Fb+E1wp0T2wY1ZT+4YdLLV0VKrmLb7NoA==;5:G/2eNpDvHStRcEjfhI8GSw84/0N5hf+XhuDp2YHrpJsHrH9/Z7bFeM4ZQPqx6ggRJ3Fb5smPG3nBEFkwMmCMOomgnL+z7bAI1aWV5fWMG+O5PUv1+wx7v2tO46IWd1MRREm/cq1T0E3ecU6p2eFHFg==;24:TKWzyaEcKDyo4TG7S5ovXmklv9rKCZmq4AT9jMINmcDNeyiHKIt2pgTIXClUBlvi0nITkOcN/L18j9yv2WToRJo+9wbpZHKa4bJEpLh18fQ=;7:DI4xZxGoYdOCFFhM3Kr3BnD6qMZuv4MRMznbfuD/eN4/zAOUJMb81kdwaSEH0R6g9QiphfpqED8ytO6hoxdwXQCyC1sBt3/7cWpG2hI0u0juajYRx4WZWq5F5XP9DHBsVBUCz503AknW252CgVw3PzaQGQN+YFu23XKi1lOwzwWNCp94QKjoGVjEerKW+u7AYuHQGJyJeOtQj8vs7TN7RuadAkHO6rt8KWBSOGaNNhQ= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1;CO1PR15MB1078;20:uzFknRIzwlRZaKcrDh1eHrQRp+yg6PUXTYLCfzu/OnZ+xc9rE7+MNT93MQ6sza2FUdl7demLt7Sd0CSc7ivQlpRZvlrGKqNiwgvC9OTRzXStOgESj+jQlxj91ZwtVeddX8n5vSMEoz50iUFHnwVwoMsKizsZk2bUgLuUTuMKC08= X-MS-Exchange-CrossTenant-OriginalArrivalTime: 26 Sep 2017 10:59:37.0346 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 8ae927fe-1255-47a7-a2af-5f3a069daaa2 X-MS-Exchange-Transport-CrossTenantHeadersStamped: CO1PR15MB1078 X-OriginatorOrg: fb.com X-Proofpoint-Spam-Reason: safe X-FB-Internal: Safe X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2017-09-26_04:,, signatures=0 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2254 Lines: 45 On Mon, Sep 25, 2017 at 10:25:21PM +0200, Michal Hocko wrote: > On Mon 25-09-17 19:15:33, Roman Gushchin wrote: > [...] > > I'm not against this model, as I've said before. It feels logical, > > and will work fine in most cases. > > > > In this case we can drop any mount/boot options, because it preserves > > the existing behavior in the default configuration. A big advantage. > > I am not sure about this. We still need an opt-in, ragardless, because > selecting the largest process from the largest memcg != selecting the > largest task (just consider memcgs with many processes example). As I understand Johannes, he suggested to compare individual processes with group_oom mem cgroups. In other words, always select a killable entity with the biggest memory footprint. This is slightly different from my v8 approach, where I treat leaf memcgs as indivisible memory consumers independent on group_oom setting, so by default I'm selecting the biggest task in the biggest memcg. While the approach suggested by Johannes looks clear and reasonable, I'm slightly concerned about possible implementation issues, which I've described below: > > > The only thing, I'm slightly concerned, that due to the way how we calculate > > the memory footprint for tasks and memory cgroups, we will have a number > > of weird edge cases. For instance, when putting a single process into > > the group_oom memcg will alter the oom_score significantly and result > > in significantly different chances to be killed. An obvious example will > > be a task with oom_score_adj set to any non-extreme (other than 0 and -1000) > > value, but it can also happen in case of constrained alloc, for instance. > > I am not sure I understand. Are you talking about root memcg comparing > to other memcgs? Not only, but root memcg in this case will be another complication. We can also use the same trick for all memcg (define memcg oom_score as maximum oom_score of the belonging tasks), it will turn group_oom into pure container cleanup solution, without changing victim selection algorithm But, again, I'm not against approach suggested by Johannes. I think that overall it's the best possible semantics, if we're not taking some implementation details into account.